内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

如何使用用戶定義的Linq表值函數(shù)

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

同江網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián)公司,同江網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為同江超過千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的同江做網(wǎng)站的公司定做!

使用用戶定義的Linq表值函數(shù)

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

下面的 SQL 用戶定義函數(shù)顯式聲明其返回一個 TABLE。因此,隱式定義了所返回的行集結(jié)構(gòu)。

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

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

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  {  }

我們可以這樣調(diào)用使用了:

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]

以聯(lián)接方式使用用戶定義的Linq表值函數(shù)

我們利用上面的ProductsUnderThisUnitPrice用戶定義函數(shù),在 LINQ to SQL 中,調(diào)用如下:

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 代碼說明對此函數(shù)返回的表執(zhí)行聯(lián)接。

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表值函數(shù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享文章:如何使用用戶定義的Linq表值函數(shù)
轉(zhuǎn)載注明:http://www.rwnh.cn/article34/pgcsse.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、網(wǎng)站維護、電子商務(wù)、微信公眾號、商城網(wǎng)站、標簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
钦州市| 莱州市| 皮山县| 施秉县| 鲁山县| 新源县| 新绛县| 石门县| 邛崃市| 黑山县| 固始县| 通辽市| 浦城县| 威信县| 六安市| 泗水县| 兴化市| 射阳县| 聂荣县| 三台县| 镇赉县| 上栗县| 舒兰市| 英吉沙县| 阿拉善右旗| 米易县| 黄陵县| 诸暨市| 安达市| 汉中市| 永济市| 夏邑县| 武汉市| 三都| 通城县| 虎林市| 翼城县| 咸阳市| 互助| 麻城市| 黄龙县|