AutoCAD.Net/C#.Net QQ群:193522571 将DataTable集合 B加入到DataTable A中,应用于两个或以上的只有单行数据的无主键的datatable的合并 Merg...

本文介绍了一种将多个只包含单行数据且无主键的DataTable进行合并的方法。通过为每个表添加临时主键并使用Merge方法完成合并,最后移除临时主键。此方法适用于需要合并多个小型数据表的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 1     /// <summary>
 2     /// 将DataTable集合 B加入到DataTable A中,应用于两个或以上的只有单行数据的无主键的datatable的合并
 3     /// </summary>
 4     /// <param name="ArrOrigeon">A</param>
 5     /// <param name="ArrAdded">B</param>
 6     /// <returns>合并后的DataTable</returns>
 7     public static sysDataTable Union(this sysDataTable tbOrigeon, params sysDataTable[] tbAdded)
 8     {
 9       sysDataTable arrs = new sysDataTable();
10       //向tbOrigeon表增加主键
11       tbOrigeon.Columns.Add("id", typeof(int));
12       tbOrigeon.Rows[0]["id"] = 1;
13       tbOrigeon.PrimaryKey = new System.Data.DataColumn[]{tbOrigeon.Columns["id"]};
14       arrs = tbOrigeon;
15       foreach (sysDataTable dt in tbAdded)
16       {
17         if (dt.Columns.Count > 0)
18         {
19           //向dt表增加主键
20           dt.Columns.Add("id", typeof(int));
21           dt.Rows[0]["id"] = 1;
22           dt.PrimaryKey = new System.Data.DataColumn[] { dt.Columns["id"] };
23           //合并表
24           arrs.Merge(dt, false);
25         }
26       }
27       //将主键置为空
28       arrs.PrimaryKey = null;
29       //删除临时主键
30       arrs.Columns.Remove("id");
31       return arrs;
32     }
View Code

 

转载于:https://www.cnblogs.com/swtool/p/4383261.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值