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

Linq表值函數詳細分析

開發 后端
這里介紹Linq表值函數返回單個行集(與存儲過程不同,存儲過程可返回多個結果形狀)。由于Linq表值函數的返回類型為 Table,因此在 SQL 中可以使用表的任何地方均可以使用Linq表值函數。

Linq有很多值得學習的地方,這里我們主要介紹Linq表值函數,包括介紹修改一下Discontinued屬性為可空的bool類型等方面。

使用用戶定義的Linq表值函數

Linq表值函數返回單個行集(與存儲過程不同,存儲過程可返回多個結果形狀)。由于Linq表值函數的返回類型為 Table,因此在 SQL 中可以使用表的任何地方均可以使用Linq表值函數。此外,您還可以完全像處理表那樣來處理Linq表值函數。

下面的 SQL 用戶定義函數顯式聲明其返回一個 TABLE。因此,隱式定義了所返回的行集結構。

  1. ALTER FUNCTION [dbo].[ProductsUnderThisUnitPrice]  
  2. (@price Money  
  3. )  
  4. RETURNS TABLE  
  5. AS  
  6. RETURN  
  7. SELECT *  
  8. FROM Products as P  
  9. Where p.UnitPrice < @price 

拖到設計器中,LINQ to SQL 按如下方式映射此函數:

  1. IsComposable=true)]  
  2. public IQueryable<ProductsUnderThisUnitPriceResult>   
  3. ProductsUnderThisUnitPrice([Parameter(DbType="Money")]  
  4. System.Nullable<decimal> price)  
  5. {  
  6. return this.CreateMethodCallQuery  
  7. <ProductsUnderThisUnitPriceResult>(this,  
  8. ((MethodInfo)(MethodInfo.GetCurrentMethod())), price);  

這時我們小小的修改一下Discontinued屬性為可空的bool類型。

  1. private System.Nullable<bool> _Discontinued;  
  2. public System.Nullable<bool> Discontinued  
  3. {  

我們可以這樣調用使用了:

  1. var q = from p in db.ProductsUnderThisUnitPrice(10.25M)  
  2. where !(p.Discontinued ?? false)  
  3. select p; 

其生成SQL語句如下:

  1. SELECT [t0].[ProductID], [t0].[ProductName], [t0].[SupplierID],   
  2. [t0].[CategoryID], [t0].[QuantityPerUnit], [t0].[UnitPrice],   
  3. [t0].[UnitsInStock], [t0].[UnitsOnOrder], [t0].[ReorderLevel],  
  4. [t0].[Discontinued]  
  5. FROM [dbo].[ProductsUnderThisUnitPrice](@p0) AS [t0]  
  6. WHERE NOT ((COALESCE([t0].[Discontinued],@p1)) = 1)  
  7. -- @p0: Input Money (Size = 0Prec = 19Scale = 4) [10.25]  
  8. -- @p1: Input Int (Size = 0Prec = 0Scale = 0) [0] 

以聯接方式使用用戶定義的Linq表值函數

我們利用上面的ProductsUnderThisUnitPrice用戶定義函數,在 LINQ to SQL 中,調用如下:

  1. var q =  
  2. from c in db.Categories  
  3. join p in db.ProductsUnderThisUnitPrice(8.50M) on  
  4. c.CategoryID equals p.CategoryID into prods  
  5. from p in prods  
  6. select new  
  7. {  
  8. c.CategoryID,  
  9. c.CategoryName,  
  10. p.ProductName,  
  11. p.UnitPrice  
  12. }; 

其生成的 SQL 代碼說明對此函數返回的表執行聯接。

  1. SELECT [t0].[CategoryID], [t0].[CategoryName],   
  2. [t1].[ProductName], [t1].[UnitPrice]  
  3. FROM [dbo].[Categories] AS [t0]  
  4. CROSS JOIN [dbo].[ProductsUnderThisUnitPrice](@p0) AS [t1]  
  5. WHERE ([t0].[CategoryID]) = [t1].[CategoryID]  
  6. -- @p0: Input Money (Size = 0Prec = 19Scale = 4) [8.50] 

【編輯推薦】

  1. Linq結果集形狀概述
  2. Linq存儲過程返回詳解
  3. Linq調用LoadProducts方法
  4. Linq使用數據表簡單描述
  5. Linq對象引用簡單介紹
責任編輯:佚名 來源: IT168
相關推薦

2009-09-14 13:50:35

LINQ編程模型

2009-09-08 15:56:50

Linq使用Group

2009-09-09 09:48:43

Linq延遲加載

2009-09-14 16:21:34

LINQ To XML

2009-09-25 14:23:39

2009-09-28 10:39:01

Hibernate基礎

2009-11-03 10:09:33

Oracle表空間

2010-01-06 13:50:37

.NET Framew

2009-11-20 13:11:44

Oracle XML數

2009-06-18 14:00:51

2009-10-10 13:52:57

VB Update方法

2009-12-03 17:41:40

PHP應用發展

2009-09-07 14:18:01

C#內存管理

2009-10-28 10:06:29

VB.NET With

2009-03-24 09:17:58

驅動GSMAndroid

2021-10-25 19:52:52

IntentFilte

2009-12-16 14:09:14

Visual Stud

2009-09-03 17:57:06

C#聲明事件

2009-09-04 15:43:07

C#流模型

2009-03-24 08:30:54

AndroidGoogle移動os
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩精品一区在线 | 九九热精品在线 | 国产精品久久久久久福利一牛影视 | www.色综合 | 国产成人网 | 国产四虎 | 亚洲欧美中文字幕在线观看 | 91久久久久久久久久久 | 国产aa| 中文字幕不卡在线88 | 久久99精品国产麻豆婷婷 | 亚洲高清视频一区二区 | 九九亚洲 | 在线观看av不卡 | 亚洲国产aⅴ精品一区二区 免费观看av | 亚洲欧美精品在线 | 成人亚洲片 | 中文字幕精品视频在线观看 | 男人的天堂中文字幕 | 欧美一级二级视频 | 天堂一区二区三区四区 | 国产色网站 | 成人精品 | 日本天堂一区 | 日本 欧美 国产 | 欧美精品网 | 草久久 | 美人の美乳で授乳プレイ | 久久精品男人的天堂 | 九九热在线免费视频 | 亚洲三级在线观看 | 欧美中文字幕一区二区三区亚洲 | 激情小说综合网 | 91在线视频观看免费 | 亚洲播放一区 | 亚洲午夜在线 | 亚洲综合国产 | 欧美日韩福利 | 亚洲综合色 | 日韩成人在线免费观看 | 日日干日日色 |