Linq有很多值得学习的地方,这里我们主要介绍Linq表值函数,包括介绍修改一下Discontinued属性为可空的bool类型等方面。
我们提供的服务有:网站建设、网站制作、微信公众号开发、网站优化、网站认证、无棣ssl等。为上千余家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的无棣网站制作公司
使用用户定义的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
- ProductsUnderThisUnitPrice([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表值函数详细分析
当前路径:http://www.csdahua.cn/qtweb/news9/277159.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网