您的位置:首页 > 数据库

关于使用dataAdapter.acceptChanges( )方法更新dataSet和数据库的问题

2008-10-16 16:26 921 查看
在winForm中实现这种效果 :

在dataGridView中任意修改数据,然后点击保存修改的按钮,将这些修改全部都一次性写入数据库。而且保存的过程中不用重新绑定dataGridView的数据源。dataGridView不用刷新。

/// <summary>

/// 将dataGridView中发生的改动提交到数据库,使用这种方法不用刷新dataGridView

/// </summary>

/// <param name="type">提示信息</param>

private void updateDataBase(string type)

{

cb = new SqlCommandBuilder(da);

da.Update(ds,"mainTable");

ds.AcceptChanges();

MessageBox.Show(type);

}

主要是使用dataAdapter的update()方法,使用这个方法之前必须先声明一个sqlCommandBuilder()。
acceptchanges()方法是提交你所做的改动。(其实感觉删掉这一行也是一样的效果)
update()方法一定要写在acceptchanges()方法之前,如果反过来的话是起不到作用的。

调用updateDataBase()方法只要这样写

ds.Tables["mainTable"].Rows[dataGridView1.CurrentRow.Index].Delete();

updateDataBase("删除成功");

第一行把DS中的Table中的当前行删除,调用updateDataBase()方法将改动存到数据库。

这个updateDataBase()方法适用于增、删、改的操作。也就是说,使用这种方式你可以用一个“保存”按钮来代替原来的“添加”“删除”“修改”三个按钮,而且代码也简洁,所有工作都交给了sqlCommandBuilder来做了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐