詳解Linq聯(lián)合查詢表結果集的返回
本文筆者詳細的介紹了Linq聯(lián)合查詢,因為怕讀者對這方面只是不是很理解,所以在講Linq聯(lián)合查詢之前先為大家做了一些知識的鋪墊,然后再具體講Linq聯(lián)合查詢是怎樣實現(xiàn)的,希望能給大家?guī)韼椭?/P>
首先,我們先來了解一些Linq聯(liá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;
 - }
 
當我們定義一個匿名類型,只能通過object類型傳遞,傳遞后編譯器將無法獲悉匿名類型的實際類型。
這行可以通過Cast擴展方法來進行強制轉換。以下是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);
 
我們再來看看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聯(lián)合查詢是怎樣實現(xiàn)的。
- 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;
 - }
 
但這個前提是業(yè)務邏輯層需要知道數據層的匿名類型中的具體類型。這樣分層的意義也就不大了。這并不是我們想要的。而且返回多行數據的結果集時用 匿名的List類型 的方法經實驗也失敗了。這就意味著本文開篇的兩種傳遞匿名類型的方法都行不通。
方法一:Linq聯(lián)合查詢自定義與返回類型相同結構的類
- public class CustomQuery
 - { public uint UnitsInStock
 - { get; set; }
 - public int Sid
 - { get; set; }
 - }
 
這樣在查詢結果為多個表的結果集時,就可以解決了。由于需要知道返回的匿名類型,除了不符合多層以外,還需要額外定義一個類。但這樣確時可以使用強類型返回我們所需要的結果。
方法二:Linq聯(lián)合查詢使用System.Func委托 (參考:Returning var from a method in C# 3.0)
數據層:
- 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è)務邏輯層:
- var results = GetCustomersWithOrders(
 - (customer, orders) => new
 - { Name = customer.Name,
 - OrderCount = orders.Count()
 - });
 
這樣返回的結果在業(yè)務邏輯層里仍然是真正的匿名類型,可以直接使用了。
方法三:Linq聯(lián)合查詢之使用存儲過程或視圖。
【編輯推薦】
 
2009-09-09 10:58:58
2009-09-17 08:47:00
2010-08-04 09:55:34
2009-11-27 09:41:56
2011-07-26 14:57:39
 
 
 














 
 
 