Intersect

DataSet ds = new DataSet(); //创建数据集
DataTable dt = CreateDataTable();//创建本地表
ds.Tables.Add(dt); //将本地表添加到数据集

//使用LINQ查询销售金额大于1000的序列
var query1 = from item in ds.Tables[0].AsEnumerable()
                   where item.Field<double>("saleAmount") > 1000
                   select item;
//使用LINQ查询数据表所有数据的序列
var query2 = from item in ds.Tables[0].AsEnumerable()
                  select item;
//获取两个集合的交集
var compare = query1.Intersect(query2);
//交集的行数与其中任一个数据表的行数相等就表示两个数据表的数据完全相同
if (query1.Count() == query2.Count() && query1.Count() == compare.Count())
           Response.Write("query1和query2中的数据完全相同");
else
           Response.Write("query1和query2中的数据不相同");

 

 

private DataTable CreateDataTable()
{
DataTable dt = new DataTable();
dt.Columns.Add("productCode", typeof(string));
dt.Columns.Add("saleDate", typeof(DateTime));
dt.Columns.Add("saleAmount", typeof(double));
DataRow dr = dt.NewRow();
dr["productCode"] = "0001";
dr["saleDate"] = Convert.ToDateTime("2009-2-1");
dr["saleAmount"] = 1000;
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["productCode"] = "0001";
dr["saleDate"] = Convert.ToDateTime("2009-1-1");
dr["saleAmount"] = 2000;
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["productCode"] = "0002";
dr["saleDate"] = Convert.ToDateTime("2009-1-1");
dr["saleAmount"] = 3000;
dt.Rows.Add(dr);
return dt;
}

转载于:https://www.cnblogs.com/Yellowshorts/archive/2013/01/18/2866620.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值