Linq表值函数详细分析
创始人
2024-06-06 14:51:30
0

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   
  3. ProductsUnderThisUnitPrice([Parameter(DbType="Money")]  
  4. System.Nullable price)  
  5. {  
  6. return this.CreateMethodCallQuery  
  7. (this,  
  8. ((MethodInfo)(MethodInfo.GetCurrentMethod())), price);  

这时我们小小的修改一下Discontinued属性为可空的bool类型。

  1. private System.Nullable _Discontinued;  
  2. public System.Nullable 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对象引用简单介绍

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...