C# 比较C语言中的两个数据集#

C# 比较C语言中的两个数据集#,c#,.net-2.0,dataset,C#,.net 2.0,Dataset,我有两个数据集,我需要比较这两个数据集,这样若一个表中不存在ID,那个么我需要编写insert Query else update Query 例如: Id in One dataset ID in second Dataset 1 1 2 2 3 4 我需要将ID 3插入第二个数据集 以下是我的代码供您参考: if

我有两个数据集,我需要比较这两个数据集,这样若一个表中不存在ID,那个么我需要编写insert Query else update Query

例如:

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() + "')");
                    }
                }
            }
        }  
if(ds.Tables[0].Rows.Count>0 | | clientDS.Tables[0].Rows.Count>0)
{
对于(int i=0;i
上面的代码不起作用。请纠正我的问题

谢谢

将这两个表(DataTable实例)添加到数据集中并添加关系

数据集ds=新数据集(); 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();
}
使用合并方法:

Dataset2.Merge(Dataset1);

这将在Dataset2中插入Dataset1中但尚未在Dataset2中的任何记录。注意:您最初的问题建议您需要插入记录或更新Dataset1中的匹配记录,但您的注释似乎表明您实际上不需要进行更新。合并方法将只插入数据集1中的新记录。

我认为您的错误是使用
==
比较Id字符串。尝试使用
Equals
。 我只需要使用foreach并选择:

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
    }
}
data2
合并到
data1
中,不覆盖具有相同主键的行,并在
data1
中添加不存在主键的行

data1.Merge(data2,false)

data2
合并为
data1
覆盖所有行并添加新行

您能否概述您的方法的工作原理,基本上写下您希望代码采取的步骤?我可以看出这里有什么问题,但唯一的解决方法是为您编写实际的代码,如果您可以编写这些步骤,然后我们可以指出这些步骤中的错误,或者在实现中的错误。Boo因为不使用参数化查询…我想您可以在所有SQL中这样做,无需使用该应用程序。第1步:从服务器数据库选择查询第2步:从客户端数据库选择查询。步骤3:比较这两个数据集。步骤4:如果客户端数据库中缺少任何行,则将服务器行插入客户端数据库。这就是我要做的。一个类似的问题很酷。我以前从未见过或使用过Merge()。很好的技术。数据集包含了处理基于表的数据所需的几乎所有方法,但程序员通常更愿意编写自己的详细技巧来完成同样的事情(这个问题提供了一些关于这种现象的优秀示例)。这两个数据集应该具有相同的模式吗?这是C#,非Java-
=
对C#中的字符串正常工作。
data1.Merge(data2,false)