gpt4 book ai didi

.net - DataTable.Merge 和 DataTable.ImportRow 不会更改 RowState

转载 作者:行者123 更新时间:2023-12-04 17:13:55 29 4
gpt4 key购买 nike

我在使用 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()
  • 数据行.SetModified()

  • 这将更新 DataRow.RowState 值。这是 DataAdapter 用来确定哪些行需要对它们执行哪些操作。

    如果它们类似于 .net 中的绑定(bind)数据集,那就太好了,这样它就可以为我们管理这些平凡的细节。

    关于.net - DataTable.Merge 和 DataTable.ImportRow 不会更改 RowState,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1460953/

    29 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com