Linq to objects(二)

DataTable products = myDataSet.Tables["products"];
DataTable classes = myDataSet.Tables["classes"];

内部连接

var result =
	from s in products
	// Inner Join表products和表classes,注意equals关键字
	join c in classes on s.cid equals c.id
	select new {
		id = s.id,          // 商品id
		name = s.name,      // 商品名称
		cname = c.name      // 分类名
	};

分组连接

var result =
	from s in products
	// 实际上就是内连接后按照cid进行分组
	join c in classes on s.cid equals c.id into G
	select new {
		id = G.Key,     // 分组的cid
		name = c.name,  // 分类名
		list = G        // 组成员,组成员为连接后的记录,字段要比之前多
	};

左外连接

var result =
	from c in classes
	join s in products on c.id = s.cid into G
	from item in G.DefaultIfEmpty()		// 当右侧products表无法匹配左表classes时,赋null
	select new {
		cname = c.name,
		list = item;	// item可能为null
	};

为null的item赋默认值

var result =
	from c in classes
	join s in products on c.id = s.cid into G
	from item in G.DefaultIfEmpty(new product{id=0, name="", cid=0})		// 当右侧products表无法匹配左表classes时,赋新建的product对象
	select new {
		cname = c.name,
		list = item;
	};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值