如圖:html
因而可知Linq表達式和Lamdba表達式並無什麼可比性。程序員
那與Lamdba表達式相關的整條語句稱做什麼呢?在微軟並無給出官方的命名,在《深刻理解C#》中稱爲點標記。sql
因此,咱們的標題的提問根本就不合適。應該是「Linq查詢表達式和點標記你更喜歡哪一個?」。如:ide
//查詢表達式 var students1 = from t in db.Students where t.Name == "張三" select new { t.Id, t.Name, t.Age }; //點標記 var students2 = db.Students .Where(t => t.Name == "張三") .Select(t => new { t.Id, t.Name, t.Age });
我相信更多的人偏向選擇點標記。具體什麼緣由我也說不清(多是點標記中的Lamdba更加優雅吧)。對於我我的來講,也是更加喜歡點標記這種方式。post
一、全部的查詢表達式均可以轉成對應的點標記。反之,不是全部的點標記均可以轉成查詢表達式。spa
爲何?由於查詢表達式在編譯後就直接變成了點標記:(如下是上面兩個語句對應的編譯後的反編譯C#代碼).net
生成了如出一轍的代碼。(因爲是編譯後的,好多亂七八糟的代碼。咱們只看Where和Select關鍵字就知道,使用的都是點標記。)3d
二、點標記確實比查詢表達式更加優雅code
例一:htm
//查詢表達式 var students1 = from t in db.Students where t.Name == "張三" select t; //點標記 var students2 = db.Students .Where(t => t.Name == "張三");
我爲何必定要 select t 啊,這句沒卵用的廢話就不能省嗎?是的,省了就報錯:
例二:
必須須要括號包裹起來才能取結果集?你還能更醜一點嗎?
//查詢表達式 var students1 = (from t in db.Students where t.Name == "張三" select t).ToList(); //點標記 var students2 = db.Students .Where(t => t.Name == "張三") .ToList();
例三:(爲何說:"不是全部的點標記均可以轉成查詢表達式"【此例只適用於IEnumerator】)
此條點標記你能轉成查詢表達式嗎?
var list = new List<string>() { "張三", "張三", "張三", "張三", "李四", "張三", "李四", "張三", "李四" }; var students2 = list .Where((item, index) => item == "張三" && index % 2 == 0) .Select((item, index) => new { item, index }) .ToList();
查詢表達式你能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();
經過上面的對比,好像查詢表達式一文不值了。no,不是這樣的。
好比下面幾種狀況咱們就能夠選擇使用查詢表達式:
例一:(本例適用於Linq to Object 和 沒有建主外鍵的EF查詢)
點標記中的Join須要傳四個參數表達式,是否是有點暈了。。。
var list1 = new Dictionary<string, string> { { "1", "張三" }, { "2", "李四" }, { "3", "張三" }, { "4", "張三" } }; var list2 = new Dictionary<string, string> { { "1", "張三" }, { "2", "李四" }, { "3", "李四" }, { "4", "張三" } }; //查詢表達式 var obj1 = from l1 in list1 join l2 in list2 on l1.Key equals l2.Key select new { l1, l2 }; //點標記 var obj = list1.Join(list2, l1 => l1.Key, l2 => l2.Key, (l1, l2) => new { l1, l2 });
例二:
點標記須要區分OrderBy、ThenBy有沒有以爲麻煩
//查詢表達式 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 }; //點標記 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 });
總以爲查詢表達式更多的只是爲了照顧那些寫慣了sql的程序員。
關於聯接查詢使用查詢表達式會更合適一些這個上面已經說了。
接下來咱們寫內聯、左聯、交叉聯的查詢表達式和對應的點標記代碼。(目的:可能有些人不會,同時在這裏也給本身作個備忘)
內聯:
左聯:
交叉聯: