linq实例 - Join的使用(四)

测试的class。public class user { private string firstName; private string lastName; private int id; public string FirstName { get { return this.firstName; } private set { } } public string LastName { get { return this.lastName; } private set { } } public int ID { get { return this.id; } private set { } } public user(string firstName, string lastName, int id) { this.firstName = firstName; this.lastName = lastName; this.id = id; } }


现在开始测试。

//准备数据。 user[] Users = new user[3]; Users[0] = new user(lastName: "Liu", firstName: "Andy", id:1); Users[1] = new user(lastName: "Gao", firstName: "Shan", id: 2); Users[2] = new user(lastName: "Liu", firstName: "Patrick", id: 3); int[] ids = new int[2]{1,3}; int[] ids2 = new int[1] { 1 }; //使用LinQ来去。意思是在Users, 把Users符合条件的记录,user的id在ids和ids2出现的记录,以LastName为group,放在usergroup里。然后把usergroup返回给newUsers var newUsers = from u in Users //看看这里就是使用join链接不同的地方。等于的时候是用equals join i in ids on u.ID equals i join i2 in ids2 on u.ID equals i2 //join可以多个。但是没有测试最多是多少个。 group u by u.LastName into usergroup select usergroup; //循环显示。 foreach (var a in newUsers) //a是group来的。可能包含不止一个记录。 { foreach(user b in a)//再次循环,把a包含的循环拿出来。这里的b是user对象了。 MessageBox.Show(String.Format("{0},{1}",b.LastName, b.FirstName)); }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值