成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解Linq聯(lián)合查詢表結果集的返回

開發(fā) 后端
本文筆者詳細的介紹了Linq聯(lián)合查詢,因為怕讀者對這方面只是不是很理解,所以在講Linq聯(lián)合查詢之前先為大家做了一些知識的鋪墊,然后再具體講Linq聯(lián)合查詢是怎樣實現(xiàn)的,希望能給大家?guī)韼椭?/div>

本文筆者詳細的介紹了Linq聯(lián)合查詢,因為怕讀者對這方面只是不是很理解,所以在講Linq聯(lián)合查詢之前先為大家做了一些知識的鋪墊,然后再具體講Linq聯(lián)合查詢是怎樣實現(xiàn)的,希望能給大家?guī)韼椭?/P>

首先,我們先來了解一些Linq聯(lián)合查詢的知識點。

1.匿名類型的傳遞

  1. static void Main(string[] args)   
  2. {   var User = GetAnonymous().Cast(new { UserName = "", LastLoginIp = "" });           
  3.    Console.Write(User.UserName);       
  4. }         
  5. static object GetAnonymous()     
  6. {     var User = new { UserName = "yaosansi", LastLoginIp = "127.0.0.1" };         
  7.       return User;     

當我們定義一個匿名類型,只能通過object類型傳遞,傳遞后編譯器將無法獲悉匿名類型的實際類型。

這行可以通過Cast擴展方法來進行強制轉換。以下是Cast方法的原型。

  1. public static T Cast(this object o, T t)       
  2. {            
  3.    return ();         

2.Linq聯(lián)合查詢之如何生成匿名類型的List?        

  1. var User = GetAnonymous().Cast(new { UserName = "", LastLoginIp = "" });         
  2. var list = new List(); 

原理和上面一致。

  1. var User = new   
  2. {     
  3.    UserName = "yaosansi", LastLoginIp = "127.0.0.1" 
  4. };              
  5. var list = User.MakeList();          
  6. list.Add(User);            
  7. Console.Write(list[0].UserName); 

我們再來看看MakeList()方法:

  1. public static List MakeList(this T t)          {             
  2.     return new List();      

當然,你可能想到上面的方法還不夠***,需要在List中Add一個User,于是有了下面的方法:       

  1. public static List MakeList(this T t,params T[] items)         
  2. {            
  3.    return new List(items);    
  4. }  

這時調用的時候可以寫成:

  1. var User = new   
  2. {   
  3.   UserName = "yaosansi", LastLoginIp = "127.0.0.1"   
  4. };              
  5. var list = User.MakeList(User);          
  6. Console.Write(list[0].UserName);   

這回我們切入正題,來了解一下Linq聯(lián)合查詢是怎樣實現(xiàn)的。

  1. var q =    from p in db.Products     
  2.  where p.Supplier.Country == "USA" && p.UnitsInStock == 0    
  3. select p; 

以上的查詢是兩個有關系的表,并且返回的只是一個表的內容,這種情況下可以在數(shù)據(jù)層中返回強類型的List。如: 

  1. public List SelectProducts()   
  2. {      var q = from p in db.Products     
  3.        where p.Supplier.Country == "USA" && p.UnitsInStock == 0        
  4.        select p;        
  5.        return q.ToList;   

 如果返回的結果集是兩個以上表的時候,那該如何傳遞呢? 聰明的你一定想到了,如果返回的是單行數(shù)據(jù)的結果集就可以我們前面提到的使用匿名類型的傳遞得到我們需要的結果. public object

  1. public object SelectProducts()  
  2. {      var q = from p in db.Products      
  3.        where p.Supplier.Country == "USA" && p.UnitsInStock == 0        
  4.        select new {p.UnitsInStock,p.Supplier.Sid};      var result = q.Single();  
  5.        return result;   
  6. }

但這個前提是業(yè)務邏輯層需要知道數(shù)據(jù)層的匿名類型中的具體類型。這樣分層的意義也就不大了。這并不是我們想要的。而且返回多行數(shù)據(jù)的結果集時用 匿名的List類型 的方法經實驗也失敗了。這就意味著本文開篇的兩種傳遞匿名類型的方法都行不通。

方法一:Linq聯(lián)合查詢自定義與返回類型相同結構的類

  1. public class CustomQuery       
  2. {  public uint UnitsInStock   
  3.    { getset; }             
  4.   public int Sid   
  5.    { getset; }        

這樣在查詢結果為多個表的結果集時,就可以解決了。由于需要知道返回的匿名類型,除了不符合多層以外,還需要額外定義一個類。但這樣確時可以使用強類型返回我們所需要的結果。

方法二:Linq聯(lián)合查詢使用System.Func委托 (參考:Returning var from a method in C# 3.0)

數(shù)據(jù)層:

  1. public IEnumerable GetCustomersWithOrders(Func
  2. TProjection> projection)   
  3. {    return from customer in _customers           
  4.      let customerOrders = from  order in _orders                                
  5.      where order.CustomerID = customer.ID             
  6.      select projection(customer, customerOrders);  

業(yè)務邏輯層:

  1. var results = GetCustomersWithOrders(  
  2. (customer, orders) => new   
  3. {   Name = customer.Name,               
  4.   OrderCount = orders.Count()        
  5. }); 

這樣返回的結果在業(yè)務邏輯層里仍然是真正的匿名類型,可以直接使用了。

方法三:Linq聯(lián)合查詢之使用存儲過程或視圖。

【編輯推薦】

  1. LINQ動態(tài)查詢的實現(xiàn)淺析
  2. LINQ TO SQL動態(tài)修改表名稱的實現(xiàn)淺析
  3. LINQ To SQL的一點討論
  4. 淺析LINQ事務處理的實現(xiàn)
  5. 淺析DataSet和DataTable
責任編輯:阡陌 來源: 博客園
相關推薦

2009-09-09 10:58:58

Linq結果集形狀

2009-09-09 11:14:04

Linq多個結果集

2009-09-17 10:27:55

linq存儲過程

2009-09-14 10:09:26

LINQ查詢結果

2009-09-09 10:54:52

Linq存儲過程返回

2009-09-08 17:27:18

LINQ to Dat

2009-09-17 08:47:00

Linq查詢

2009-09-15 13:28:49

LINQ表間關系查詢

2009-09-14 14:49:12

LINQ查詢基礎知識

2023-10-27 11:15:18

內存query打印

2009-08-27 09:13:28

LINQ查詢表達式

2009-11-27 09:41:56

LINQ

2010-08-04 09:55:34

LINQ to SQL

2010-11-23 15:59:16

MySQL表結果集

2011-08-23 10:14:09

JDBC更新計數(shù)行調用存儲過程SQL Server

2009-09-09 13:53:21

Linq表值函數(shù)

2011-08-29 11:38:18

SQL Server 聯(lián)合結果集union

2010-01-08 13:23:38

ibmdwInfoSphere

2009-09-14 18:53:27

LINQ查詢

2009-09-14 18:41:59

LINQ查詢
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品久久影院 | 国产视频久久久 | 国内久久精品 | 国产精品久久久久久久久动漫 | 午夜欧美 | 久久久久国产成人精品亚洲午夜 | 三级成人片| 91久久久久| 国产成人99久久亚洲综合精品 | 欧美激情欧美激情在线五月 | 91在线观看视频 | 91传媒在线播放 | 欧美日韩精品一区二区天天拍 | 国产在线色 | 亚洲不卡在线观看 | 一区二区在线观看免费视频 | 日本中文字幕一区 | 欧美一级免费黄色片 | 国产成人在线播放 | 中文字幕 国产精品 | 91国内精精品久久久久久婷婷 | 乱码av午夜噜噜噜噜动漫 | 亚洲区一 | 嫩草视频在线免费观看 | 精品一区二区三区免费视频 | 亚洲免费网 | 欧美一区二区三区在线观看视频 | 365夜爽爽欧美性午夜免费视频 | 欧美一区二区三区国产 | 好好的日在线视频 | 欧美精品中文字幕久久二区 | 欧美大片久久久 | 欧美日韩在线精品 | 在线午夜电影 | 91精品国产综合久久久动漫日韩 | 久久久久亚洲精品 | 亚洲成av片人久久久 | 91在线网| 99久久久无码国产精品 | 国产偷录视频叫床高潮对白 | 国产精品久久久久久久免费大片 |