C#datatable的问题,datatable1(dt1)主表datatable2(dt2)次表

如何把dt1中有,dt2中没有的数据全部赋值到dt3中注:dt2就是显示了一部分的dt1中的数据我想查出没显示的哪些求高手告诉我一下代码谢谢... 如何把dt1中有,dt2中没有的数据 全部赋值到dt3中
注:dt2 就是显示了一部分的dt1中的数据 我想查出没显示的哪些
求高手告诉我一下代码 谢谢
展开
 我来答
然后去远足
2015-09-23 · TA获得超过1万个赞
知道大有可为答主
回答量:4016
采纳率:83%
帮助的人:2401万
展开全部

本质上就是取 dt1、dt2 的非重复项(非交集),方法有很多。


1、最笨的一种是循环遍历,两层 for 循环。


2、如果存在唯一性 Key 的话(可以理解为主键),那么把 dt2 中的这些 Key 取出,从 dt1(或其副本)中删除,剩下的自然就是非重复项。


3、先对两表中的某一字段进行排序,然后用二分法做检索,相当于对第一种方法做了搜索优化。


4、如果是 .NET 3.5 或以上,可以利用 Linq:

var dt3 = from r in dt1.AsEnumerable()
    where !(
        from rr in dt2.AsEnumerable()
        select rr.Field<int>("Id")
    ).Contains(r.Field<int>("Id"))
    select r; // 假设存在唯一性 Key:Id
追问
懂了,非常感谢
handangaoyang
2015-09-23 · TA获得超过2242个赞
知道大有可为答主
回答量:2633
采纳率:88%
帮助的人:904万
展开全部

dt1与dt2,是以某一个字段来判断两条记录是否相同?

List<DataRow> rows1 = dt1.Rows.Cast<DataRow>();
List<DataRow> rows2 = dt2.Rows.Cast<DataRow>();
List<DataRow> rows3 = rows1.Except(rows2,new DataRowComparer());

public class DataRowComparer : IEqualityComparer<DataRow>
{
    public bool Equals(DataRow x, DataRow y)
    {
        if (x == null && y == null)
            return true;
        else if (x == null || y == null)
            return false;
        else
            return x["字段"].Equals(y["字段"]);
    }

    public int GetHashCode(DataRow obj)
    {
        return obj.GetHashCode();
    }
}
追问
这个太麻烦了,我只需要简单的dt1,dt2数据的差异比较,不要新的方法 比较是用的ID
追答
确是没有你采纳的简单。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
小简麦垛cZb76
2015-09-23 · TA获得超过245个赞
知道小有建树答主
回答量:274
采纳率:0%
帮助的人:169万
展开全部
bool flag;
foreach(DataRow row1 in dt1.Rows){
flag = true;
foreach(DataRow row2 in dt2.Rows){
if(row1["id"]==row2["id"])//如果dt2就是显示了一部分的dt1中的数据,id为主键
flag=false;
}
if(flag){
object[] row= new object[dt1.Columns.Count];
row1.ItemArray.CopyTo(lastValues, 0);
dt3.Rows.add(row);
}
}
更多追问追答
追问
object[] row= new object[dt1.Columns.Count];
row1.ItemArray.CopyTo(lastValues, 0);
问一下,这两句是什么意思
追答
就是建一个object数组,长度和row1相同;
将row1的所有值赋给这个object数组
(备注:已存在在dt中的dr不能给另外一个dt.rows.add的,只能新建一个数组完成这步骤)
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式