C#中LINQ多條件JOIN時爲什麼可以使用匿名類

這篇文章主要給大家介紹了關於C#中LINQ多條件JOIN時爲什麼可以使用匿名類的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑑,下面來一起看看吧

前言

本文主要介紹的是關於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對匿名類對象和具名類對象的處理不太一致

進一步瞭解才發現,

C#中,對匿名類的做了重寫,使得最開始LINQ中的條件判斷能夠成功。不過,根據測試能發現,要讓兩個匿名對象相等,屬性屬性,屬性名和屬性值都必須一致才行。

進一步瞭解爲什麼equals對具名類對象的表現與匿名類對象的差異,發現equals只是object的虛方法,測試中自定義的類沒有重寫equals,再調用中調用了objects的方法而返回false。同時,也可以參考這個朋友的文章瞭解更多。

如下,是從SO上找到的關於“==”與equals的區別

所以,通常equals比較的兩個對象的內容,“==”比較的是兩者是否是同一個東西。在自定義的類中,如果要用到對象比較,可以根據需要重寫equals來控制判斷邏輯。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章