(轉(zhuǎn))Linq表達(dá)式舆蝴、Lambda表達(dá)式你更喜歡哪個(gè)?

什么是Linq表達(dá)式题诵?什么是Lambda表達(dá)式洁仗?

如圖:


image

由此可見Linq表達(dá)式和Lambda表達(dá)式并沒有什么可比性。

那與Lambda表達(dá)式相關(guān)的整條語(yǔ)句稱作什么呢性锭?在微軟并沒有給出官方的命名赠潦,在《深入理解C#》中稱為點(diǎn)標(biāo)記。


image

查詢表達(dá)式草冈、點(diǎn)標(biāo)記你更喜歡哪個(gè)祭椰?

所以臭家,我們的標(biāo)題的提問根本就不合適。應(yīng)該是“查詢表達(dá)式和點(diǎn)標(biāo)記你更喜歡哪個(gè)方淤?”钉赁。如:

//查詢表達(dá)式
 var students1 = from t in db.Students
                where t.Name == "張三"
                select new { t.Id, t.Name, t.Age };
 //點(diǎn)標(biāo)記
 var students2 = db.Students
                 .Where(t => t.Name == "張三")
                 .Select(t => new { t.Id, t.Name, t.Age });

為什么選擇點(diǎn)標(biāo)記

我相信更多的人偏向選擇點(diǎn)標(biāo)記。具體什么原因我也說不清(可能是點(diǎn)標(biāo)記中的Lambda更加優(yōu)雅吧)携茂。對(duì)于我個(gè)人來說你踩,也是更加喜歡點(diǎn)標(biāo)記這種方式。

1讳苦、所有的查詢表達(dá)式都可以轉(zhuǎn)成對(duì)應(yīng)的點(diǎn)標(biāo)記带膜。反之,不是所有的點(diǎn)標(biāo)記都可以轉(zhuǎn)成查詢表達(dá)式鸳谜。

為什么膝藕?因?yàn)椴樵儽磉_(dá)式在編譯后就直接變成了點(diǎn)標(biāo)記:(以下是上面兩個(gè)語(yǔ)句對(duì)應(yīng)的編譯后的反編譯C#代碼)


image

生成了一模一樣的代碼。(由于是編譯后的咐扭,好多亂七八糟的代碼芭挽。我們只看Where和Select關(guān)鍵字就知道,使用的都是點(diǎn)標(biāo)記蝗肪。)

2袜爪、點(diǎn)標(biāo)記確實(shí)比查詢表達(dá)式更加優(yōu)雅
例一:

//查詢表達(dá)式
 var students1 = from t in db.Students
                 where t.Name == "張三"
                 select t;
 //點(diǎn)標(biāo)記
 var students2 = db.Students
                 .Where(t => t.Name == "張三");

我為什么一定要 select t 啊,這句沒卵用的廢話就不能省嗎薛闪?是的辛馆,省了就報(bào)錯(cuò):

image

例二:
必須需要括號(hào)包裹起來才能取結(jié)果集?你還能更丑一點(diǎn)嗎豁延?

//查詢表達(dá)式
var students1 = (from t in db.Students
                 where t.Name == "張三"
                 select t).ToList();
//點(diǎn)標(biāo)記
var students2 = db.Students
                .Where(t => t.Name == "張三")
                .ToList();

例三:(為什么說:"不是所有的點(diǎn)標(biāo)記都可以轉(zhuǎn)成查詢表達(dá)式"【此例只適用于IEnumerator】)

此條點(diǎn)標(biāo)記你能轉(zhuǎn)成查詢表達(dá)式嗎昙篙?

var list = new List<string>() { "張三", "張三", "張三", "張三", "李四", "張三", "李四", "張三", "李四" };

var students2 = list
                .Where((item, index) => item == "張三" && index % 2 == 0)
                .Select((item, index) => new { item, index })
                .ToList();

查詢表達(dá)式你能Reverse嗎?

var list = new List<string>() { "張三1", "張三2", "張三3", "張三0", "李四9", "張三3", "李四", "張三2", "李四" };

var students2 = list
             .Where((item, index) => item.Contains("張三"))
             .Select((item, index) => new { item, index })
             .Reverse()//反序
             .ToList();

ListA.Distinct().ToList();//去重
ListA.Except(ListB).ToList();//差集
ListA.Union(ListB).ToList(); //并集
ListA.Intersect(ListB).ToList();//交集

什么時(shí)候使用查詢表達(dá)式诱咏?

通過上面的對(duì)比瓢对,好像查詢表達(dá)式一文不值了。no胰苏,不是這樣的。

比如下面幾種情況我們就可以選擇使用查詢表達(dá)式:

例一:(本例適用于Linq to Object 和 沒有建主外鍵的EF查詢)

點(diǎn)標(biāo)記中的Join需要傳四個(gè)參數(shù)表達(dá)式,是不是有點(diǎn)暈了。而克。功炮。

var list1 = new Dictionary<string, string> { { "1", "張三" }, { "2", "李四" }, { "3", "張三" }, { "4", "張三" } };
var list2 = new Dictionary<string, string> { { "1", "張三" }, { "2", "李四" }, { "3", "李四" }, { "4", "張三" } };

//查詢表達(dá)式
var obj1 = from l1 in list1
           join l2 in list2
           on l1.Key equals l2.Key
           select new { l1, l2 };
//點(diǎn)標(biāo)記
var obj = list1.Join(list2, l1 => l1.Key, l2 => l2.Key, (l1, l2) => new { l1, l2 });

例二:

點(diǎn)標(biāo)記需要區(qū)分OrderBy、ThenBy有沒有覺得麻煩

//查詢表達(dá)式
var obj1 = from l1 in list1
           join l2 in list2
           on l1.Key equals l2.Key
           orderby l1.Key, l2.Key descending
           select new { l1, l2 };
//點(diǎn)標(biāo)記
var obj = list1.Join(list2, l1 => l1.Key, l2 => l2.Key, (l1, l2) => new { l1, l2 })
    .OrderBy(li => li.l1.Key)
    .ThenByDescending(li => li.l2.Key)
    .Select(t => new { t.l1, t.l2 });

總覺得查詢表達(dá)式更多的只是為了照顧那些寫慣了sql的程序員氏堤。

聯(lián)接查詢(內(nèi)聯(lián)、左聯(lián)、交叉聯(lián))

關(guān)于聯(lián)接查詢使用查詢表達(dá)式會(huì)更合適一些這個(gè)上面已經(jīng)說了陕赃。

接下來我們寫內(nèi)聯(lián)卵蛉、左聯(lián)、交叉聯(lián)的查詢表達(dá)式和對(duì)應(yīng)的點(diǎn)標(biāo)記代碼么库。(目的:可能有些人不會(huì)傻丝,同時(shí)在這里也給自己做個(gè)備忘)

內(nèi)聯(lián):


image

左聯(lián):


image

交叉聯(lián):
image

其實(shí)關(guān)于聯(lián)接查詢,如果EF建好了主外鍵我還是覺得點(diǎn)標(biāo)記用起來更爽爽的诉儒。

結(jié)束:

本文并不是要改變你的習(xí)慣葡缰,也不是否定你的觀點(diǎn)。僅僅只是表達(dá)個(gè)人對(duì)點(diǎn)標(biāo)記和查詢表達(dá)式的些許理解忱反。

關(guān)于是使用查詢表達(dá)式還是點(diǎn)標(biāo)記泛释,可能起著更大決定性的作用的是團(tuán)隊(duì)共同的習(xí)慣和規(guī)范。

然后還想說說温算,只要我們對(duì)比什么怜校,很可能就會(huì)有人跳出了,什么不要比注竿,用好了都一樣茄茁,什么什么才是最重要的,什么什么的蔓搞。胰丁。。

就像很多人會(huì)反感java和C#的對(duì)比喂分,其實(shí)我個(gè)人覺得對(duì)比下底層實(shí)現(xiàn)锦庸、對(duì)比下語(yǔ)法簡(jiǎn)易也不是不可以的,只要我們可以從中學(xué)到知識(shí)(個(gè)人也是不喜歡對(duì)比 誰誰誰學(xué)什么工資多少多少)蒲祈。

昨天的自己對(duì)比今天的自己甘萧,今天的自己對(duì)比明天的自己。只要可以進(jìn)步為什么不要對(duì)比呢梆掸?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末扬卷,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子酸钦,更是在濱河造成了極大的恐慌怪得,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件卑硫,死亡現(xiàn)場(chǎng)離奇詭異徒恋,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)欢伏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門入挣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人硝拧,你說我怎么就攤上這事径筏「鸺伲” “怎么了?”我有些...
    開封第一講書人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵滋恬,是天一觀的道長(zhǎng)聊训。 經(jīng)常有香客問我,道長(zhǎng)夷恍,這世上最難降的妖魔是什么魔眨? 我笑而不...
    開封第一講書人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮酿雪,結(jié)果婚禮上遏暴,老公的妹妹穿的比我還像新娘。我一直安慰自己指黎,他們只是感情好朋凉,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著醋安,像睡著了一般杂彭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上吓揪,一...
    開封第一講書人閱讀 51,482評(píng)論 1 302
  • 那天亲怠,我揣著相機(jī)與錄音,去河邊找鬼柠辞。 笑死团秽,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的叭首。 我是一名探鬼主播习勤,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼焙格!你這毒婦竟也來了图毕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤眷唉,失蹤者是張志新(化名)和其女友劉穎予颤,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冬阳,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蛤虐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了摩泪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡劫谅,死狀恐怖见坑,靈堂內(nèi)的尸體忽然破棺而出嚷掠,到底是詐尸還是另有隱情,我是刑警寧澤荞驴,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布不皆,位于F島的核電站,受9級(jí)特大地震影響熊楼,放射性物質(zhì)發(fā)生泄漏霹娄。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一鲫骗、第九天 我趴在偏房一處隱蔽的房頂上張望犬耻。 院中可真熱鬧,春花似錦执泰、人聲如沸枕磁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)计济。三九已至,卻和暖如春排苍,著一層夾襖步出監(jiān)牢的瞬間沦寂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工淘衙, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留传藏,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓幔翰,卻偏偏與公主長(zhǎng)得像漩氨,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子遗增,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容