您好,登錄后才能下訂單哦!
本篇內容介紹了“Linq聯合查詢表結果集的返回怎么實現”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
首先,我們先來了解一些Linq聯合查詢的知識點。
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; }
當我們定義一個匿名類型,只能通過object類型傳遞,傳遞后編譯器將無法獲悉匿名類型的實際類型。
這行可以通過Cast擴展方法來進行強制轉換。以下是Cast方法的原型。
public static T Cast(this object o, T t) { return (); }
2.Linq聯合查詢之如何生成匿名類型的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);
我們再來看看MakeList()方法:
public static List MakeList(this T t) { return new List(); }
當然,你可能想到上面的方法還不夠***,需要在List中Add一個User,于是有了下面的方法:
public static List MakeList(this T t,params T[] items) { return new List(items); }
這時調用的時候可以寫成:
var User = new { UserName = "yaosansi", LastLoginIp = "127.0.0.1" }; var list = User.MakeList(User); Console.Write(list[0].UserName);
這回我們切入正題,來了解一下Linq聯合查詢是怎樣實現的。
var q = from p in db.Products where p.Supplier.Country == "USA" && p.UnitsInStock == 0 select p;
以上的查詢是兩個有關系的表,并且返回的只是一個表的內容,這種情況下可以在數據層中返回強類型的List。如:
public List SelectProducts() { var q = from p in db.Products where p.Supplier.Country == "USA" && p.UnitsInStock == 0 select p; return q.ToList; }
如果返回的結果集是兩個以上表的時候,那該如何傳遞呢? 聰明的你一定想到了,如果返回的是單行數據的結果集就可以我們前面提到的使用匿名類型的傳遞得到我們需要的結果. 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; }
但這個前提是業務邏輯層需要知道數據層的匿名類型中的具體類型。這樣分層的意義也就不大了。這并不是我們想要的。而且返回多行數據的結果集時用 匿名的List類型 的方法經實驗也失敗了。
方法一:Linq聯合查詢自定義與返回類型相同結構的類
public class CustomQuery { public uint UnitsInStock { get; set; } public int Sid { get; set; } }
這樣在查詢結果為多個表的結果集時,就可以解決了。由于需要知道返回的匿名類型,除了不符合多層以外,還需要額外定義一個類。但這樣確時可以使用強類型返回我們所需要的結果。
方法二:Linq聯合查詢使用System.Func委托 (參考:Returning var from a method in C# 3.0)
數據層:
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); }
業務邏輯層:
var results = GetCustomersWithOrders( (customer, orders) => new { Name = customer.Name, OrderCount = orders.Count() });
這樣返回的結果在業務邏輯層里仍然是真正的匿名類型,可以直接使用了。
“Linq聯合查詢表結果集的返回怎么實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。