加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何正确地将bindingSource更改提交到源数据库?

发布时间:2020-12-16 01:50:27 所属栏目:百科 来源:网络整理
导读:我设置了DataGridView和其他UI组件,以允许用户编辑来自SQLite DB的数据.但是这些更改(即使它们在应用程序中正确显示)也不会保存到DB.我试过这段代码 aBindingSource.EndEdit();dbDataSetA.GetChanges();aTableAdapter.Update(dbDataSetA.Accounts); 但是有并
我设置了DataGridView和其他UI组件,以允许用户编辑来自SQLite DB的数据.但是这些更改(即使它们在应用程序中正确显示)也不会保存到DB.我试过这段代码

aBindingSource.EndEdit();
dbDataSetA.GetChanges();
aTableAdapter.Update(dbDataSetA.Accounts);

但是有并发异常:

System.Data.DBConcurrencyException was unhandled Message=Concurrency
violation: the UpdateCommand affected 0 of the expected 1 records.

那么我应该如何将绑定源更改提交给DB,伙计们呢?

编辑后
我在启动程序时遇到此异常,然后单击DataGridView中的第二行,然后单击第三行,此时程序引发并发异常.希望他的帮助能让这个问题更加详细.

先谢谢你们!

解决方法

像这样的东西?

try
{
   aBindingSource.EndEdit();
   dbDataSetA.GetChanges();
   aTableAdapter.Update(dbDataSetA.Accounts);   
}
catch (DBConcurrencyException exc)
{
   MessageBox.Show("original data changed,please redo updates");
   aTableAdapter.Fill(dbDataSetA);
}

然后根据需要将dbDataSetA重新分配为DataSource,用户必须再次输入数据.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读