ASP.NET合并两个相关联的DataTable
类别:编程学习 浏览量:4750
时间:2013-11-30 ASP.NET合并两个相关联的DataTable
ASP.NET合并两个相关联的DataTable分为两种情况:DataTable1和DataTable2结构相同、DataTable1和DataTable2结构不同,下面分别介绍怎么进行合并。
一、DataTable1和DataTable2结构相同的情况
结构相同我们只需要把两者的数据罗列到一块就可以了
合并方法1:用Rows.Add方法
DataTable newDataTable = DataTable1.Clone();
object[] obj = new object[newDataTable.Columns.Count];
//添加DataTable1的数据
for (int i = 0; i < DataTable1.Rows.Count; i++)
{
DataTable1.Rows[i].ItemArray.CopyTo(obj, 0);
newDataTable.Rows.Add(obj);
}
//添加DataTable2的数据
for (int i = 0; i < DataTable2.Rows.Count; i++)
{
DataTable2.Rows[i].ItemArray.CopyTo(obj, 0);
newDataTable.Rows.Add(obj);
}
合并方法2:用DataTable.ImportRow方法
//拷贝DataTable1的结构和数据
DataTable newDataTable = DataTable1.Copy();
//添加DataTable2的数据
foreach (DataRow dr in DataTable2.Rows)
{
newDataTable.ImportRow(dr);
}
二、DataTable1和DataTable2结构不同相同的情况
我们可以先向新表中添加DataTable1的数据,然后再向每行的后面添加添加DataTable2的数据,注意两者的行数不一定相同。
方法(1)先添加第一个表,再添加第二个表
/// <summary>
/// 将两个列不同(结构不同)的DataTable合并成一个新的DataTable
/// </summary>
/// <param name="DataTable1">表1</param>
/// <param name="DataTable2">表2</param>
/// <param name="DTName">合并后新的表名</param>
/// <returns>合并后的新表</returns>
private DataTable UniteDataTable(DataTable DataTable1, DataTable DataTable2, string DTName)
{
//克隆DataTable1的结构
DataTable newDataTable = DataTable1.Clone();
for (int i = 0; i < DataTable2.Columns.Count; i++)
{
//再向新表中加入DataTable2的列结构
newDataTable.Columns.Add(DataTable2.Columns[i].ColumnName);
}
object[] obj = new object[newDataTable.Columns.Count];
//添加DataTable1的数据
for (int i = 0; i < DataTable1.Rows.Count; i++)
{
DataTable1.Rows[i].ItemArray.CopyTo(obj, 0);
newDataTable.Rows.Add(obj);
}
if (DataTable1.Rows.Count >= DataTable2.Rows.Count)
{
for (int i = 0; i < DataTable2.Rows.Count; i++)
{
for (int j = 0; j < DataTable2.Columns.Count; j++)
{
newDataTable.Rows[i][j + DataTable1.Columns.Count] = DataTable2.Rows[i][j].ToString();
}
}
}
else
{
DataRow dr3;
//向新表中添加多出的几行
for (int i = 0; i < DataTable2.Rows.Count - DataTable1.Rows.Count; i++)
{
dr3 = newDataTable.NewRow();
newDataTable.Rows.Add(dr3);
}
for (int i = 0; i < DataTable2.Rows.Count; i++)
{
for (int j = 0; j < DataTable2.Columns.Count; j++)
{
newDataTable.Rows[i][j + DataTable1.Columns.Count] = DataTable2.Rows[i][j].ToString();
}
}
}
newDataTable.TableName = DTName; //设置DT的名字
return newDataTable;
方法(2)先添加行数多的表。其实我们也可以先判断哪个表的行数多,就先添加哪个表,然后再添加行少的表就可以了。
/// <summary>
/// 将两个列不同(结构不同)的DataTable合并成一个新的DataTable
/// </summary>
/// <param name="DataTable1">表1</param>
/// <param name="DataTable2">表2</param>
/// <param name="DTName">合并后新的表名</param>
/// <returns>合并后的新表</returns>
private DataTable UniteDataTable2(DataTable DataTable1, DataTable DataTable2, string DTName)
{
DataTable newDataTable = new DataTable();
if (DataTable1.Rows.Count > DataTable2.Rows.Count)
{
newDataTable = FillData(DataTable1, DataTable2);
}
else
{
newDataTable = FillData(DataTable2, DataTable1);
}
newDataTable.TableName = DTName; //设置DT的名字
return newDataTable;
}
private DataTable FillData(DataTable dt1, DataTable dt2)
{
//克隆DataTable1的结构
DataTable newDataTable = dt1.Clone();
for (int i = 0; i < dt2.Columns.Count; i++)
{
//再向新表中加入DataTable2的列结构
newDataTable.Columns.Add(dt2.Columns[i].ColumnName);
}
object[] obj = new object[newDataTable.Columns.Count];
//添加DataTable1的数据
for (int i = 0; i < dt1.Rows.Count; i++)
{
dt1.Rows[i].ItemArray.CopyTo(obj, 0);
newDataTable.Rows.Add(obj);
}
for (int i = 0; i < dt2.Rows.Count; i++)
{
for (int j = 0; j < dt2.Columns.Count; j++)
{
newDataTable.Rows[i][j + dt1.Columns.Count] = dt2.Rows[i][j].ToString();
}
}
return newDataTable;
}
您可能感兴趣
- asp.net如何实现word文档在线预览
- ASP.NET中() => 的含义
- ASP.NET写文件的方法
- ASP.NET实现多文件上传
- ASP.NET中application对象的用法
- ASP.NET URL路径问题
- ASP.NET Web API中参数的传递
- ASP.NET实现FTP上传文件
- ASP.NET中XML和JSON互转
- ASP.NET压力测试
- asp.net中split的用法
- asp.net 参数化like模糊查询
- asp.net去除字符串中html标签
- asp.net小数点四舍五入
- ASP.NET抓取网页内容
- ASP.NET中Obsolete属性
- 冬季钓鱼子线用 长 还是 短(冬季钓鱼子线用)
- 鱼竿 夏钓短,冬钓长 ,一定是这样 认清优缺点在选竿(鱼竿夏钓短冬钓长)
- 鲢鳙钓底还是钓浮 流水的水域应怎样做钓(鲢鳙钓底还是钓浮)
- 入秋后的第二场苹果发布会来了 全新M1系列芯片登场(入秋后的第二场苹果发布会来了)
- 苹果正式发布自研芯片M1 5nm 32核心 彻底放弃Intel(苹果正式发布自研芯片M1)
- 苹果自研芯片跑分对比 A16芯片排名靠后,M1系列霸榜(苹果自研芯片跑分对比)
热门推荐
- mysql索引失效原因(MySQL索引失效的几种情况详析)
- apache设置站点(Apache 多端口多站点配置方法)
- mysql数据库主键选择的详解(图文详解MySQL中的主键与事务)
- wamp服务器的配置文件包含(解析关于wamp启动是80端口被占用的问题)
- mongovue的使用
- 在php中与数据库连接的技术(PHP7.0连接DB操作实例分析基于mysqli)
- nginx反向代理spring boot(Nginx+SpringBoot实现负载均衡的示例)
- sqlserver数据库备份还原(sqlserver数据库高版本备份还原为低版本的方法)
- border和background区别(css中background-origin属性的使用解析)
- python转图片为字符图(Python实现图片转字符画的代码实例)