将两个列不同的DataTable合并成一个新的DataTable
2013-09-03 09:04
846 查看
/// <summary>
/// 将两个列不同(结构不同)的DataTable合并成一个新的DataTable
/// </summary>
/// <param name="DataTable1">表1</param>
/// <param name="DataTable2">表2</param>
/// <returns>合并后的新表</returns>
private DataTable UniteDataTable(DataTable DataTable1, DataTable DataTable2)
{
//克隆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();
}
}
}
return newDataTable;
}
#endregion
/// 将两个列不同(结构不同)的DataTable合并成一个新的DataTable
/// </summary>
/// <param name="DataTable1">表1</param>
/// <param name="DataTable2">表2</param>
/// <returns>合并后的新表</returns>
private DataTable UniteDataTable(DataTable DataTable1, DataTable DataTable2)
{
//克隆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();
}
}
}
return newDataTable;
}
#endregion
相关文章推荐
- 将两个列不同的DataTable合并成一个新的DataTable
- C# 将两个不同的dataTable合并到一个自定义的dataTable中
- C# 将两个不同的dataTable合并到一个自定义的dataTable中
- [VB.NET]vb.net中如何将两个结构不同的DATATABLE合并成一个DATATABLE
- 将两个DataTable合并成一个DataTable
- 两个结构不同的DataTable合并
- 比较两个DataTable中不同的记录,且合并两个DataTable的列显示,有图
- c# dataTable 合并两个列到一个新列中的简单实例
- 两个DataTable合并成一个DataTable
- c# 对两个Datatable的结构相同进行合并,结构相同和不同
- 将两个DataTable合并成一个Datatable
- 将两个DataTable合并成一个DataTable
- 比较两个DataTable中不同的记录,且合并两个DataTable的列显示,有图
- 同一个数据库里,两个相同字段但是顺序不同的数据表合并教程
- sql语句——不同的表根据相同的字段值将两个表指定的字段合并为一个表
- 将两个DataTable合并成一个DataTable
- 把两个DataTable合并成一个
- 将两个DataTable合并成一个DataTable
- C# 合并两个不同的DataTable
- 两个DataTable合并为一个DataTable