C#中LINQ多條件JOIN時(shí)為什么可以使用匿名類
前言
本文主要介紹的是關(guān)于C#中LINQ多條件JOIN時(shí)為什么可以使用匿名類的相關(guān)內(nèi)容,分享出來(lái)供大家參考學(xué)習(xí),下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧
我們先來(lái)看一下linq中如何在join中指定多個(gè)條件
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時(shí)為什么可以使用匿名類
最近心血來(lái)潮突然想弄明白為什么LINQ中多條件JOIN的時(shí)候,使用new 匿名類就能成功,這是為什么呢?為什么LINQ用的equals 而不是常見(jiàn)的“==”?
隨后,進(jìn)行了如下的測(cè)試,發(fā)現(xiàn)equals對(duì)匿名類對(duì)象和具名類對(duì)象的處理不太一致
進(jìn)一步了解才發(fā)現(xiàn),
C#中,對(duì)匿名類的做了重寫(xiě),使得最開(kāi)始LINQ中的條件判斷能夠成功。不過(guò),根據(jù)測(cè)試能發(fā)現(xiàn),要讓兩個(gè)匿名對(duì)象相等,屬性屬性,屬性名和屬性值都必須一致才行。
進(jìn)一步了解為什么equals對(duì)具名類對(duì)象的表現(xiàn)與匿名類對(duì)象的差異,發(fā)現(xiàn)equals只是object的虛方法,測(cè)試中自定義的類沒(méi)有重寫(xiě)equals,再調(diào)用中調(diào)用了objects的方法而返回false。同時(shí),也可以參考這個(gè)朋友的文章了解更多。
如下,是從SO上找到的關(guān)于“==”與equals的區(qū)別,
所以,通常equals比較的兩個(gè)對(duì)象的內(nèi)容,“==”比較的是兩者是否是同一個(gè)東西。在自定義的類中,如果要用到對(duì)象比較,可以根據(jù)需要重寫(xiě)equals來(lái)控制判斷邏輯。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)我們的支持。
欄 目:C#教程
下一篇:C#將配置文件appsetting中的值轉(zhuǎn)換為動(dòng)態(tài)對(duì)象調(diào)用
本文標(biāo)題:C#中LINQ多條件JOIN時(shí)為什么可以使用匿名類
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5082.html
您可能感興趣的文章
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并打開(kāi)的方法
- 01-10C#實(shí)現(xiàn)多線程下載文件的方法
- 01-10C#實(shí)現(xiàn)Winform中打開(kāi)網(wǎng)頁(yè)頁(yè)面的方法
- 01-10C#實(shí)現(xiàn)由四周向中心縮小的窗體退出特效
- 01-10C#實(shí)現(xiàn)多線程寫(xiě)入同一個(gè)文件的方法
- 01-10Extjs4如何處理后臺(tái)json數(shù)據(jù)中日期和時(shí)間
- 01-10C#中DataGridView常用操作實(shí)例小結(jié)
- 01-10C#編程獲取資源文件中圖片的方法
- 01-10asp.net中XML如何做增刪改查操作
- 01-10C#利用反射技術(shù)實(shí)現(xiàn)去掉按鈕選中時(shí)的邊框效果


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻 器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫(xiě)Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-10delphi制作wav文件的方法
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?