本文主要是介绍关于使用dataAdapter.acceptChanges( )方法更新dataSet和数据库的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在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来做了。
这篇关于关于使用dataAdapter.acceptChanges( )方法更新dataSet和数据库的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!