本质上就是取 dt1、dt2 的非重复项(非交集),方法有很多。
1、最笨的一种是循环遍历,两层 for 循环。
2、如果存在唯一性 Key 的话(可以理解为主键),那么把 dt2 中的这些 Key 取出,从 dt1(或其副本)中删除,剩下的自然就是非重复项。
3、先对两表中的某一字段进行排序,然后用二分法做检索,相当于对第一种方法做了搜索优化。
4、如果是 .NET 3.5 或以上,可以利用 Linq:
var dt3 = from r in dt1.AsEnumerable()
where !(
from rr in dt2.AsEnumerable()
select rr.Field("Id")
).Contains(r.Field("Id"))
select r; // 假设存在唯一性 Key:Id
dt1与dt2,是以某一个字段来判断两条记录是否相同?
Listrows1 = dt1.Rows.Cast ();
Listrows2 = dt2.Rows.Cast ();
Listrows3 = rows1.Except(rows2,new DataRowComparer());
public class DataRowComparer : IEqualityComparer
{
public bool Equals(DataRow x, DataRow y)
{
if (x == null && y == null)
return true;
else if (x == null || y == null)
return false;
else
return x["字段"].Equals(y["字段"]);
}
public int GetHashCode(DataRow obj)
{
return obj.GetHashCode();
}
}
bool flag;
foreach(DataRow row1 in dt1.Rows){
flag = true;
foreach(DataRow row2 in dt2.Rows){
if(row1["id"]==row2["id"])//如果dt2就是显示了一部分的dt1中的数据,id为主键
flag=false;
}
if(flag){
object[] row= new object[dt1.Columns.Count];
row1.ItemArray.CopyTo(lastValues, 0);
dt3.Rows.add(row);
}
}