一、DataTable1和DataTable2结构相同的情况
结构相同我们只需要把两者的数据罗列到一块就可以了
合并方法:用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);
}
二、DataTable1和DataTable2结构不同相同的情况
我们可以先向新表中添加DataTable1的数据,然后再向每行的后面添加添加DataTable2的数据,注意两者的行数不一定相同。
合并方法:先添加行数多的表。其实我们也可以先判断哪个表的行数多,就先添加哪个表,然后再添加行少的表就可以了。
/** <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合并两个相关联的DataTable http://www.studyofnet.com/news/239.html