发布网友 发布时间:2022-05-19 17:15
共2个回答
懂视网 时间:2022-05-19 21:36
写了个函数.
/// <summary>
/// 合并两个相同的DataTable,返回合并后的结果
/// </summary>
/// <param name="dt1"></param>
/// <param name="dt2"></param>
/// <returns></returns>
public DataTable CombineTheSameDatatable(DataTable dt1, DataTable dt2)
{
if (dt1.Rows.Count == 0 && dt2.Rows.Count == 0)
{
return new DataTable();
}
if (dt1.Rows.Count == 0)
{
return dt2;
}
if (dt2.Rows.Count == 0)
{
return dt1;
}
DataSet ds = new DataSet();
ds.Tables.Add(dt1.Copy());
ds.Merge(dt2.Copy());
return ds.Tables[0];
}
由于对C#的理解有限,所以不明白为什么用dt1==null不能正确判断空表,所以用了数行的方法.还望高人能指点一二.热心网友 时间:2022-05-19 18:44
/// <summary>
/// 生成空表
/// </summary>
private DataTable getEmptyTable()
{
DataTable dt = new DataTable();
dt.Columns.Add(new DataColumn("ID", typeof(int)));
dt.Columns.Add(new DataColumn("Name", typeof(string)));
dt.Columns.Add(new DataColumn("Age", typeof(int)));
dt.Columns.Add(new DataColumn("Sex", typeof(int)));
return dt;
}
/// <summary>
/// 表
/// </summary>
private DataTable getTable()
{
DataTable dt = getEmptyTable();
DataRow dr;
foreach(每一个记录 逻辑判读,此处比较简单,故省略)
{
dr = dt.NewRow();
dr[0] = 数据;
dr[1] = 数据;
dr[2] = 数据;
dr[3] = 数据;
dr[4] = 数据;
dt.Rows.Add(dr);
}
Return dt;
}