C#中LINQ多条件JOIN时为什么可以使用匿名类

2020-01-05 09:29:39王旭

前言

本文主要介绍的是关于C#中LINQ多条件JOIN时为什么可以使用匿名类的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

我们先来看一下linq中如何在join中指定多个条件


public ActionResult Edit(int id)
  {
   using (DataContext db = new DataContext(ConfigurationManager.ConnectionStrings["sqlConnection"].ConnectionString))
   {
    IQueryable<ClassInformation> result = from c in db.GetTable<TClass>()
              join t in db.GetTable<TTeacher>()
              on new { id = c.ID, id1 = c.ID } 
              equals new { id = t.ClassID, id1 = id }
              select new ClassInformation { ID = c.ID, ClassID = t.ClassID, Name = c.Name, TeacherName = t.Name, Address = t.Address, Phone = t.Phone, Email = t.Email };
    ClassInformation k = result.Single();
    ViewData["K"] = k;
    return View();


   }

  }

C#中LINQ多条件JOIN时为什么可以使用匿名类

最近心血来潮突然想弄明白为什么LINQ中多条件JOIN的时候,使用new 匿名类就能成功,这是为什么呢?为什么LINQ用的equals 而不是常见的“==”?

C#,LINQ,JOIN,匿名类

随后,进行了如下的测试,发现equals对匿名类对象和具名类对象的处理不太一致

C#,LINQ,JOIN,匿名类