DataTable删除行却更新不了数据库

dongfengkuayue 2014-07-28 10:25:00
DataTable删除行却更新不了数据库:



DataTable table = ……; //获取已有的DataTable变量,具体方法的就省略了

DataRow found = FindRowByID(rowID); //定位其中一行

table.Rows.Remove(found);//删除改行

using (SqlConnection connection = new SqlConnection("……"))
{
connection.Open();
SqlDataAdapter dataAdpater = new SqlDataAdapter("select * from [dbo].[Gatway]", connection);
SqlCommandBuilder sqlBuilder = new SqlCommandBuilder(dataAdpater);
dataAdpater.UpdateCommand = sqlBuilder.GetUpdateCommand();
dataAdpater.Update(table);

connection.Close();
}


通过上面这种方法删除了一行并Update到数据库。
通过验证,发现数据库中该行依然存在,搞不懂为什么。


后来将删除行的语句改为:
table.Rows[rowIndex].Delete();


然后再Update到数据库就能够成功删除行。
求大神指点一下这其中的原因
...全文
584 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
支持曹版,DataTable是有行状态的,你在执行了Delete()方法之后,行状态依然是已经修改的Modified,但是数据依然存在。只有执行了AcceptChanges之后,这一行的状态才会变成 Deleted,这时候你更新数据库,这一行才真正被删除。如果想访问被删除的行, 可以使用: DataTable.Rows[索引,DataRowVersion.original] 这样就是访问在调用 AcceptChanges 之前的数据了
threenewbee 2014-07-28
  • 打赏
  • 举报
回复
调用table.AcceptChanges
dongfengkuayue 2014-07-28
  • 打赏
  • 举报
回复
datatable删除一个行怎么有这么多函数

62,244

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧