首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过DataAdapter删除行

通过DataAdapter删除行
EN

Stack Overflow用户
提问于 2010-11-29 16:39:21
回答 5查看 13.1K关注 0票数 3

我已经初始化了一个dataAdapter:

代码语言:javascript
复制
string sql = "SELECT * From localitati";
da1 = new System.Data.SqlClient.SqlDataAdapter(sql, con);
da1.Fill(ds1, "localitati");

这个可以很好的工作。问题是当我试图删除一条记录并更新数据库时。我从数据集中删除一条记录,如下所示:

代码语言:javascript
复制
ds1.Tables["localitati"].Rows.Remove(dRow);

这也能很好地工作(经过验证)。

问题是当我更新DataAdapter时,DataBase没有被修改:

代码语言:javascript
复制
con.Open()
da1.Update(ds1, "localitati");
con.Close();

可能的问题是什么?

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2010-11-29 16:58:07

您需要确保设置了da1.DeleteCommand -这是将为DataTable中已删除的每一行触发的命令。请参见this MSDN reference示例。

票数 1
EN

Stack Overflow用户

发布于 2012-08-21 08:18:10

修复它的方法是在DataRow上调用Delete方法,而不是在DataTable上调用Remove方法。

代码语言:javascript
复制
ds.Tables["localitati"].Rows.Find(primaryKeyValue).Delete();

或者只是简单地

代码语言:javascript
复制
dr.Delete();
票数 13
EN

Stack Overflow用户

发布于 2010-11-29 16:43:57

尝试下面的代码,假设Database没有抛出任何异常。

代码语言:javascript
复制
con.Open() 
da1.Update(ds1.Tables["localitati"].GetChanges()); 
con.Close(); 
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4302052

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档