如何使用用户定义的Linq表值函数
发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,小编给大家分享一下如何使用用户定义的Linq表值函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!使用用户定义的Linq表
千家信息网最后更新 2025年01月21日如何使用用户定义的Linq表值函数
小编给大家分享一下如何使用用户定义的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 IQueryableProductsUnderThisUnitPrice([Parameter(DbType="Money")] System.Nullable price) { return this.CreateMethodCallQuery (this, ((MethodInfo)(MethodInfo.GetCurrentMethod())), price); }
这时我们小小的修改一下Discontinued属性为可空的bool类型。
private System.Nullable_Discontinued; public System.Nullable 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表值函数"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
函数
用户
篇文章
内容
方式
类型
过程
面的
其生
处理
存储
不同
不怎么
代码
单个
地方
多个
大部分
对此
属性
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
软件开发毕业论文包含
软件开发世界最牛的语言
360dns服务器
图书管理系统数据库表
源代码管理买哪个云服务器好
查数据库表空间
熊片数据库新
数据库如何去掉重复列
窄带软件开发
上海智能边缘计算服务器供应费用
四川优质软件开发价格
网络安全工程师证书要学多久
网络安全市场分析规划报告
数据库中代号
软件开发好网站
mysql数据库转码工具
重庆网络安全和信息化
老牌数据服务器软件有哪些
昌平区口碑好的软件开发诚信服务
软件开发算法先行
阿里轻量服务器远程连接
世界互联网科技成果中国商飞
mac系统怎么进去数据库
微信开发 服务器
数据库互斥
松江区咨询软件开发销售方法
佛山自主可控软件开发供应商家
重庆直播场控软件开发
高斯200数据库对应函数
网络工程专业中网络安全