[代码]如何使用用户定义的标量值函数(LINQ to SQL)

本文介绍如何在LINQtoSQL中映射SQL用户定义的标量值函数,并提供具体示例代码。重点讲解了FunctionAttribute.IsComposable属性的作用及设置方法。

此示例代码主要用来示范如何在LINQ to SQL的对象模型中生成映射到SQL用户定义的标量值函数的函数。
SQL Server的标量值函数通常类似与如下的定义:
CREATE FUNCTION ReverseCustName(@CustomerID nchar(5)) RETURNS nvarchar(30) AS BEGIN DECLARE @CustomerName nvarchar(30) SELECT @CustomerName = [ContactName] FROM [Customers] WHERE [CustomerID] = @CustomerID RETURN @CustomerName END
诸如如上所定义的标量值函数,可以通过下面的做法将其映射到对象模型中的函数。
特别需要注意的是FunctionAttribute.IsComposable必须设置为true,如果为false则表示映射的是存储过程,而不是用户自定义函数。
[Function(Name="dbo.ReverseCustName", IsComposable=true)] public string ReverseCustomerName( [Parameter(Name="CustomerID", DbType="NChar(5)")]string CustomerID) { IExecuteResult Result = this.ExecuteMethodCall(this, (MethodInfo)MethodInfo.GetCurrentMethod(), CustomerID); return (string)Result.ReturnValue; }
接着就可以通过类似如下的代码来调用上面定义的映射函数,从而达到调用数据库中用户自定义的标量值函数的目的。
在这个代码中,则是通过客户的编号获取客户的联系名。然后将其打印到控制台上。
NorthwindDataContext db = new NorthwindDataContext(@"C:/LINQ/Northwind.mdf"); string CustomerName = db.ReverseCustomerName("ALFKI"); Console.WriteLine(CustomerName);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值