在C#中比较两个数据集

4
我有两个数据集,需要比较这两个数据集,如果一个表中的ID在另一个表中不存在,则需要编写插入查询,否则需要编写更新查询。
例如:
Id in One dataset        ID in second Dataset       
1                          1
2                          2
3                          4

我需要将ID 3插入到第二个数据集中。
以下是参考代码:
if (ds.Tables[0].Rows.Count > 0 || clientDS.Tables[0].Rows.Count > 0)
        {
            for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
            {
                for (int j = 0; j < clientDS.Tables[0].Rows.Count; j++)
                {
                    if (ds.Tables[0].Rows[i]["Id"].ToString() == clientDS.Tables[0].Rows[j]["Id"].ToString())
                    {
                        client.GetSingleValue("update customers set Name='" + ds.Tables[0].Rows[i]["Name"].ToString() + "',ContactPerson= '" + ds.Tables[0].Rows[i]["ContactPerson"].ToString() + "',Address='" + ds.Tables[0].Rows[i]["Address"].ToString() + "',TinNo='" + ds.Tables[0].Rows[i]["TinNo"].ToString() + "',ContactNo='" + ds.Tables[0].Rows[i]["Contactno"].ToString() + "',Report=  '" + ds.Tables[0].Rows[i]["Report"].ToString() + "',Sync=0,Ids='" + ds.Tables[0].Rows[i]["Id"].ToString() + "' where id='" + ds.Tables[0].Rows[i]["Id"].ToString() + "' ");
                    }
                    else
                    {
                        client.GetSingleValue("insert into customers(id,Name,ContactPerson,Address,TinNo,ContactNo,Report,Sync,Ids) values('" + ds.Tables[0].Rows[i]["Id"].ToString() + "',  '" + ds.Tables[0].Rows[i]["Name"].ToString() + "','" + ds.Tables[0].Rows[i]["ContactPerson"].ToString() + "',  '" + ds.Tables[0].Rows[i]["Address"].ToString() + "',  '" + ds.Tables[0].Rows[i]["TinNo"].ToString() + "',  '" + ds.Tables[0].Rows[i]["Contactno"].ToString() + "',  '" + ds.Tables[0].Rows[i]["Report"].ToString() + "',0,'" + ds.Tables[0].Rows[i]["Id"].ToString() + "')");
                    }
                }
            }
        }  

上面的代码无法工作。请纠正我的问题。
谢谢。

你能概述一下你的方法是如何工作的吗?基本上写下你想让代码执行的步骤。我可以看出这里有什么问题,但唯一修复它的方法就是为你编写实际的代码,如果你能写出步骤,那么我们可以指出这些步骤中的错误或实现中的错误。 - Lasse V. Karlsen
6
不使用参数化查询,呸! - Thorsten Dittmar
1
我认为你可以在所有的SQL中完成这个,不需要使用应用层。 - San Jacinto
步骤1:从服务器数据库选择查询。 步骤2:从客户端数据库选择查询。 步骤3:比较这两个数据集。 步骤4:如果客户端数据库中缺少任何行,则将服务器行插入到客户端数据库中。这就是我要做的全部。 - GIRISH GMAIL
一个类似的问题 比较数据集或更好的想法 + c# 2.0 - rahul
请访问以下链接,您将得到解决方案:http://www.dotnetspider.com/forum/287063-How-compare-two-dataset-dt1-dt2-store-unmatched-rows-dt3.aspx - user1784766
4个回答

7
使用合并方法:
Dataset2.Merge(Dataset1);

这将会把Dataset1中所有不在Dataset2中的记录插入到Dataset2中。注意:您最初的问题暗示您需要从Dataset1中插入记录或更新匹配的记录,但是您的评论似乎表明您实际上并不需要进行更新。Merge方法只会从Dataset1插入新的记录。


很酷啊。我从来没有见过或使用过Merge()。好棒的技巧。 - Dave Markle
1
数据集包括几乎所有需要处理基于表格的数据的方法,但程序员通常更愿意编写自己复杂的代码来完成同样的任务(本问题提供了一些很好的例子)。 - MusiGenesis
1
这两个数据集是否应该具有相同的模式? - GIRISH GMAIL

3
DataSet data1
DataSet data2

data1.Merge(data2,true)

data2合并到data1中,不会覆盖具有相同主键的行,并且会添加在data1中不存在的主键行。

data1.Merge(data2,false)

data2合并到data1中,覆盖所有行并添加新行。


2

我认为你的错误在于使用==来比较Id字符串。尝试使用Equals

我会建议使用foreach和select代替:

foreach (DataRow row in ds.Tables[0].Rows)
{
    string filter = string.Format("Id = '{0}'", row["Id"]);
    DataRow[] rows = clientDS.Tables[0].Select(filter);
    if (rows.length == 0)
    {
        // insert here
    }
    else
    {
        // update here
    }
}

4
这是C#,不是Java - 在C#中,==运算符对于字符串的比较是正确的。 - MusiGenesis

1
将这两个表(DataTable实例)添加到一个DataSet中并建立关系。
DataSet ds = new DataSet(); ds.EnforceConstraints = false;
DataTable dt1 = new DataTable("A");
DataTable dt2 = new DataTable("B");

dt1.Columns.Add("ID", typeof(int));
dt1.PrimaryKey = new DataColumn[] {dt1.Columns[0]};
dt1.Rows.Add(1);
dt1.Rows.Add(2);
dt1.Rows.Add(3);

dt2.Columns.Add("ID", typeof(int));
dt2.Rows.Add(1);
dt2.Rows.Add(2);
dt2.Rows.Add(4);

ds.Tables.Add(dt1);
ds.Tables.Add(dt2);
ds.Relations.Add("ID_REL", dt1.Columns[0], dt2.Columns[0]);

foreach (DataRow r in ds.Tables["A"].Rows)
{
    DataRow []child=r.GetChildRows("ID_REL");
    Console.Write(r[0] + " " );
    if (child.Length != 0)
        Console.WriteLine(child[0][0]);

    Console.WriteLine();
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接