千家信息网

LINQ to SQL如何输出参数

发表于:2025-01-17 作者:千家信息网编辑
千家信息网最后更新 2025年01月17日,这篇文章将为大家详细讲解有关LINQ to SQL如何输出参数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。LINQ to SQL输出参数映射到引用参数,并且对于值
千家信息网最后更新 2025年01月17日LINQ to SQL如何输出参数

这篇文章将为大家详细讲解有关LINQ to SQL如何输出参数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

LINQ to SQL输出参数映射到引用参数,并且对于值类型,它将参数声明为可以为 null。

下面的示例带有单个输入参数(客户 ID)并返回一个输出参数(该客户的总销售额)。

ALTER PROCEDURE [dbo].[CustOrderTotal]   @CustomerID nchar(5),  @TotalSales money OUTPUT  AS  SELECT @TotalSales = SUM(OD.UNITPRICE*(1-OD.DISCOUNT) * OD.QUANTITY)  FROM ORDERS O, "ORDER DETAILS" OD  where O.CUSTOMERID = @CustomerID AND O.ORDERID = OD.ORDERID

其生成代码如下:

[Function(Name="dbo.CustOrderTotal")]  public int CustOrderTotal(  [Parameter(Name="CustomerID", DbType="NChar(5)")]string customerID,  [Parameter(Name="TotalSales", DbType="Money")]  ref System.Nullable totalSales)  {  IExecuteResult result = this.ExecuteMethodCall(this,  ((MethodInfo)(MethodInfo.GetCurrentMethod())),  customerID, totalSales);  totalSales = ((System.Nullable)  (result.GetParameterValue(1)));  return ((int)(result.ReturnValue));  }

我们使用下面的语句调用此存储过程:注意:LINQ to SQL输出参数是按引用传递的,以支持参数为"in/out"的方案。在这种情况下,参数仅为"out"。

decimal? totalSales = 0;  string customerID = "ALFKI";  db.CustOrderTotal(customerID, ref totalSales);  Console.WriteLine("Total Sales for Customer '{0}' = {1:C}",   customerID, totalSales);

语句描述:这个实例使用返回 Out 参数的存储过程。

关于"LINQ to SQL如何输出参数"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

0