91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-12-01 16:51:57 來源:億速云 閱讀:110 作者:小新 欄目:編程語言

小編給大家分享一下如何使用用戶定義的Linq表值函數,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

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

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

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

ALTER FUNCTION [dbo].[ProductsUnderThisUnitPrice]  (@price Money  )  RETURNS TABLE  AS  RETURN  SELECT *  FROM Products as P  Where p.UnitPrice < @price

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

IsComposable=true)]  public IQueryable<ProductsUnderThisUnitPriceResult>   ProductsUnderThisUnitPrice([Parameter(DbType="Money")]  System.Nullable<decimal> price)  {  return this.CreateMethodCallQuery  <ProductsUnderThisUnitPriceResult>(this,  ((MethodInfo)(MethodInfo.GetCurrentMethod())), price);  }

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

private System.Nullable<bool> _Discontinued;  public System.Nullable<bool> Discontinued  {  }

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

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

其生成SQL語句如下:

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

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

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

var q =  from c in db.Categories  join p in db.ProductsUnderThisUnitPrice(8.50M) on  c.CategoryID equals p.CategoryID into prods  from p in prods  select new  {  c.CategoryID,  c.CategoryName,  p.ProductName,  p.UnitPrice  };

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

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

以上是“如何使用用戶定義的Linq表值函數”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安仁县| 宿松县| 封开县| 安溪县| 夏邑县| 北碚区| 台南市| 通海县| 三明市| 丰都县| 晋中市| 临夏县| 探索| 集贤县| 华宁县| 舟曲县| 介休市| 赤峰市| 襄城县| 德格县| 喜德县| 临高县| 青铜峡市| 无极县| 高邑县| 靖远县| 观塘区| 永胜县| 长汀县| 阿勒泰市| 拉萨市| 宿迁市| 朝阳区| 隆回县| 客服| 上杭县| 金阳县| 通州区| 团风县| 固原市| 大城县|