关于使用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来做了。
在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来做了。
相关文章推荐
- 通过 SqlDataAdapter.update 方法通过DataSet更新数据库
- C# 使用DataSet+dataAdapter操作后台数据库之事务处理方法1,欢迎拍砖
- C#中DataSet、SqlDataAdapter的使用-关于数据库操作
- <转载>C#使用SqlDataAdapter.Update更新数据库
- 关于win10周年版更新后无法正常使用vc6.0问题的解决方法
- 用SqlDataAdapter更新数据库问题
- iOS 关于UICollectionView选中状态,当使用reloadData方法时出现数据的问题?
- C#使用DataSet Datatable更新数据库的三种实现方法
- 关于Dataset,Sqlcommand,Sqldataadapter及相关的类的问题
- 对于使用Context.SaveChanges()方法,数据库不更新
- 关于使用CreateUserWinzard控件创建用户时出现连接数据库问题的解决方法
- DataGridView(C#使用SqlDataAdapter.Update更新数据库)
- 关于LR中lrs_accept_connection函数中获取data.ws中端口号问题解决方法
- Delphi XE8中开发DataSnap程序常见问题和解决方法 (二)想对DBExpress的TSQLDataSet写对数据库操作的SQL语句出错了!
- (应用程序无法正常启动0xc0000142) 关于win10周年版更新后无法正常使用vc6.0问题的解决方法
- 关于Jpa使用Update方法进行更新操作,却没有同步到数据库的原因
- 关于ASP.NET“操作必须使用一个可更新的查询”问题的解决方法
- C#使用DataSet Datatable更新数据库的三种实现方法
- zend framework 中使用dbadapter操作数据库的几种方法(持续更新)
- 用SqlDataAdapter.Update(DataSet Ds)更新数据库