前言
本文主要介绍的是关于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 而不是常见的“==”?
随后,进行了如下的测试,发现equals对匿名类对象和具名类对象的处理不太一致











