本篇內(nèi)容介紹了“Linq聯(lián)合查詢表結(jié)果集的返回怎么實(shí)現(xiàn)”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)公司專注于企業(yè)網(wǎng)絡(luò)營(yíng)銷(xiāo)推廣、網(wǎng)站重做改版、撫寧網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5網(wǎng)站設(shè)計(jì)、商城開(kāi)發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、成都外貿(mào)網(wǎng)站建設(shè)公司、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為撫寧等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。
首先,我們先來(lái)了解一些Linq聯(lián)合查詢的知識(shí)點(diǎn)。
1.匿名類(lèi)型的傳遞
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è)匿名類(lèi)型,只能通過(guò)object類(lèi)型傳遞,傳遞后編譯器將無(wú)法獲悉匿名類(lèi)型的實(shí)際類(lèi)型。
這行可以通過(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)合查詢之如何生成匿名類(lèi)型的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í)候可以寫(xiě)成:
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)類(lèi)型的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é)果集就可以我們前面提到的使用匿名類(lèi)型的傳遞得到我們需要的結(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ù)層的匿名類(lèi)型中的具體類(lèi)型。這樣分層的意義也就不大了。這并不是我們想要的。而且返回多行數(shù)據(jù)的結(jié)果集時(shí)用 匿名的List類(lèi)型 的方法經(jīng)實(shí)驗(yàn)也失敗了。
方法一:Linq聯(lián)合查詢自定義與返回類(lèi)型相同結(jié)構(gòu)的類(lèi)
public class CustomQuery { public uint UnitsInStock { get; set; } public int Sid { get; set; } }這樣在查詢結(jié)果為多個(gè)表的結(jié)果集時(shí),就可以解決了。由于需要知道返回的匿名類(lèi)型,除了不符合多層以外,還需要額外定義一個(gè)類(lèi)。但這樣確時(shí)可以使用強(qiáng)類(lèi)型返回我們所需要的結(jié)果。
方法二:Linq聯(lián)合查詢使用System.Func委托 (參考:Returning var from a method in C# 3.0)
數(shù)據(jù)層:
public IEnumerable GetCustomersWithOrders(Func<Customer, IEnumerable, 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ù)邏輯層里仍然是真正的匿名類(lèi)型,可以直接使用了。
“Linq聯(lián)合查詢表結(jié)果集的返回怎么實(shí)現(xiàn)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
文章題目:Linq聯(lián)合查詢表結(jié)果集的返回怎么實(shí)現(xiàn)
URL網(wǎng)址:http://www.chinadenli.net/article30/gjospo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、電子商務(wù)、App設(shè)計(jì)、網(wǎng)站導(dǎo)航、品牌網(wǎng)站制作、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
移動(dòng)網(wǎng)站建設(shè)知識(shí)