我在 ADO.NET 2.0 合并/导入数据时遇到问题。我需要将数据从一个通用表更新/插入到另一个表,并且两个表都保持相同的架构。以下代码在本地运行良好,但不会对数据库进行更改:
OleDbDataAdapter localDA = loadLocalData();
OleDbDataAdapter hostedDA = loadHostedData();
DataSet dsLocal = new DataSet();
localDA.Fill(dsLocal);
DataSet dsChanges = new DataSet();
hostedDA.Fill(dsChanges);
dsLocal.Tables[0].Merge(dsChanges.Tables[0],false);
localDA.Update(dsLocal.Tables[0]);
此代码片段也是如此:
OleDbDataAdapter localDA = loadLocalData();
OleDbDataAdapter hostedDA = loadHostedData();
DataSet dsLocal = new DataSet();
localDA.Fill(dsLocal);
DataSet dsChanges = new DataSet();
hostedDA.Fill(dsChanges);
foreach (DataRow changedRow in dsChanges.Tables[0].Rows)
{
if (recordExists(dsLocal.Tables[0], changedRow["ID"]))
{
}
else
{
dsLocal.Tables[0].ImportRow(changedRow);
}
}
localDA.Update(dsLocal.Tables[0]);
当我查看已更改/附加行的 RowState 属性时,它们保持“不变”。我希望尽可能避免数据映射列,这就是我可能必须使用 NewRow() 方法并修改现有行所做的事情。
您需要为每个 DataRow 触发适当的函数。
- DataRow.SetAdded()
- DataRow.SetModified()
这将更新 DataRow.RowState 值。这就是 DataAdapter 用来确定哪些行需要对其执行哪些操作的依据。
如果它们类似于 .net 中的绑定数据集,那就太好了,这样它就可以为我们管理这些平凡的细节。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)