linq的内连接,分组连接,左外连接

本文介绍了LINQ中的连接操作,包括内连接、分组连接和左外连接。内连接通过join字句和join方法获取两个对象的交集。分组连接使用into关键字,生成左侧源序列与右侧源序列的分层关联结果。而左外连接结合DefaultIfEmpty方法,确保返回左侧序列的所有元素,即使右侧无匹配项。文中通过学生和老师类的实例代码详细解析了各种连接操作的用法和结果。
摘要由CSDN通过智能技术生成

通用类和字段

定义老师类和学生类,学生类中有老师的ID

 public class Student
        {
   
            public int Id {
    get; set; }
            public string Name {
    get; set; }
            public int TeacherID {
    get; set; }
        }
        public class Teacher
        {
   
            public int Id {
    get; set; }
            public string Name {
    get; set; }
        }

定义一个连接后的数据类

  public class StuTea
        {
   
            public int StuId {
    get; set; }
            public string StuName {
    get; set; }
            public int TeaId {
    get; set; }
            public string TeaName {
    get; set; }

            public override string ToString()
            {
   
                return string.Format("学生id:{0},学生name:{1},老师id:{2},老师name:{3}",StuId,StuName,TeaId,TeaName);
            }
        }
          public class StuTeaG
        {
   
            public Student Stu {
    get; set; }
            public Teacher Tea {
    get; set; }
           
            public override string ToString()
            {
   
                return string.Format("学生id:{0},学生name:{1},老师id:{2},老师name:{3}",
                    Stu==null?-1: Stu.Id,Stu==null?"": Stu.Name, Tea == null?-1: Tea.Id, Tea == null?"": Tea.Name);
            }
        }

初始化学生数据和老师数据

   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值