新聞中心
本文筆者詳細(xì)的介紹了Linq聯(lián)合查詢,因?yàn)榕伦x者對(duì)這方面只是不是很理解,所以在講Linq聯(lián)合查詢之前先為大家做了一些知識(shí)的鋪墊,然后再具體講Linq聯(lián)合查詢是怎樣實(shí)現(xiàn)的,希望能給大家?guī)?lái)幫助。

創(chuàng)新互聯(lián)主要從事成都做網(wǎng)站、網(wǎng)站建設(shè)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)芮城,十多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):028-86922220
首先,我們先來(lái)了解一些Linq聯(lián)合查詢的知識(shí)點(diǎn)。
1.匿名類型的傳遞
- static void Main(string[] args)
- { var User = GetAnonymous().Cast(new { UserName = "", LastLoginIp = "" });
- Console.Write(User.UserName);
- }
- static object GetAnonymous()
- { var User = new { UserName = "yaosansi", LastLoginIp = "127.0.0.1" };
- return User;
- }
當(dāng)我們定義一個(gè)匿名類型,只能通過(guò)object類型傳遞,傳遞后編譯器將無(wú)法獲悉匿名類型的實(shí)際類型。
這行可以通過(guò)Cast擴(kuò)展方法來(lái)進(jìn)行強(qiáng)制轉(zhuǎn)換。以下是Cast方法的原型。
- public static T Cast ( this object o, T t)
- {
- return ();
- }
2.Linq聯(lián)合查詢之如何生成匿名類型的List?
- var User = GetAnonymous().Cast(new { UserName = "", LastLoginIp = "" });
- var list = new List ();
原理和上面一致。
- var User = new
- {
- UserName = "yaosansi", LastLoginIp = "127.0.0.1"
- };
- var list = User.MakeList();
- list.Add(User);
- Console.Write(list[0].UserName);
我們?cè)賮?lái)看看MakeList()方法:
- public static List MakeList ( this T t) {
- return new List ();
- }
當(dāng)然,你可能想到上面的方法還不夠***,需要在List中Add一個(gè)User,于是有了下面的方法:
- public static List MakeList ( this T t,params T[] items)
- {
- return new List (items);
- }
這時(shí)調(diào)用的時(shí)候可以寫成:
- var User = new
- {
- UserName = "yaosansi", LastLoginIp = "127.0.0.1"
- };
- var list = User.MakeList(User);
- Console.Write(list[0].UserName);
這回我們切入正題,來(lái)了解一下Linq聯(lián)合查詢是怎樣實(shí)現(xiàn)的。
- var q = from p in db.Products
- where p.Supplier.Country == "USA" && p.UnitsInStock == 0
- select p;
以上的查詢是兩個(gè)有關(guān)系的表,并且返回的只是一個(gè)表的內(nèi)容,這種情況下可以在數(shù)據(jù)層中返回強(qiáng)類型的List。如:
- public List SelectProducts()
- { var q = from p in db.Products
- where p.Supplier.Country == "USA" && p.UnitsInStock == 0
- select p;
- return q.ToList ;
- }
如果返回的結(jié)果集是兩個(gè)以上表的時(shí)候,那該如何傳遞呢? 聰明的你一定想到了,如果返回的是單行數(shù)據(jù)的結(jié)果集就可以我們前面提到的使用匿名類型的傳遞得到我們需要的結(jié)果. public object
- public object SelectProducts()
- { var q = from p in db.Products
- where p.Supplier.Country == "USA" && p.UnitsInStock == 0
- select new {p.UnitsInStock,p.Supplier.Sid}; var result = q.Single();
- return result;
- }
但這個(gè)前提是業(yè)務(wù)邏輯層需要知道數(shù)據(jù)層的匿名類型中的具體類型。這樣分層的意義也就不大了。這并不是我們想要的。而且返回多行數(shù)據(jù)的結(jié)果集時(shí)用 匿名的List類型 的方法經(jīng)實(shí)驗(yàn)也失敗了。這就意味著本文開篇的兩種傳遞匿名類型的方法都行不通。
方法一:Linq聯(lián)合查詢自定義與返回類型相同結(jié)構(gòu)的類
- public class CustomQuery
- { public uint UnitsInStock
- { get; set; }
- public int Sid
- { get; set; }
- }
這樣在查詢結(jié)果為多個(gè)表的結(jié)果集時(shí),就可以解決了。由于需要知道返回的匿名類型,除了不符合多層以外,還需要額外定義一個(gè)類。但這樣確時(shí)可以使用強(qiáng)類型返回我們所需要的結(jié)果。
方法二:Linq聯(lián)合查詢使用System.Func委托 (參考:Returning var from a method in C# 3.0)
數(shù)據(jù)層:
- public IEnumerable GetCustomersWithOrders (Func ,
- TProjection> projection)
- { return from customer in _customers
- let customerOrders = from order in _orders
- where order.CustomerID = customer.ID
- select projection(customer, customerOrders);
- }
業(yè)務(wù)邏輯層:
- var results = GetCustomersWithOrders(
- (customer, orders) => new
- { Name = customer.Name,
- OrderCount = orders.Count()
- });
這樣返回的結(jié)果在業(yè)務(wù)邏輯層里仍然是真正的匿名類型,可以直接使用了。
方法三:Linq聯(lián)合查詢之使用存儲(chǔ)過(guò)程或視圖。
【編輯推薦】
- LINQ動(dòng)態(tài)查詢的實(shí)現(xiàn)淺析
- LINQ TO SQL動(dòng)態(tài)修改表名稱的實(shí)現(xiàn)淺析
- LINQ To SQL的一點(diǎn)討論
- 淺析LINQ事務(wù)處理的實(shí)現(xiàn)
- 淺析DataSet和DataTable
分享題目:詳解Linq聯(lián)合查詢表結(jié)果集的返回
鏈接分享:http://www.dlmjj.cn/article/ccdccjh.html


咨詢
建站咨詢
