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)); 
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值