Linq存储过程返回详解

开发 后端
这里介绍Linq存储过程返回,从数据库中返回行集合,并包含用于筛选结果的输入参数。 当我们执行返回行集合的存储过程时,会用到结果类,它存储从存储过程中返回的结果。

学习Linq时,经常会遇到Linq存储过程返回问题,这里将介绍Linq存储过程返回问题的解决方法。

存储过程

在我们编写程序中,往往需要一些存储过程,在LINQ to SQL中怎么使用呢?也许比原来的更简单些。下面我们以NORTHWND.MDF数据库中自带的几个存储过程来理解一下。

1.标量返回

在数据库中,有名为Customers Count By Region的存储过程。该Linq存储过程返回顾客所在"WA"区域的数量。

  1. ALTER PROCEDURE [dbo].[NonRowset]  
  2. (@param1 NVARCHAR(15))  
  3. AS  
  4. BEGIN  
  5. SET NOCOUNT ON;  
  6. DECLARE @count int  
  7. SELECT @count = COUNT(*)FROM Customers   
  8. WHERECustomers.Region = @Param1  
  9. RETURN @count  
  10. END 

我们只要把这个存储过程拖到O/R设计器内,它自动生成了以下代码段:

  1. [Function(Name = "dbo.[Customers Count By Region]")]  
  2. public int Customers_Count_By_Region([Parameter  
  3. (DbType = "NVarChar(15)")] string param1)  
  4. {  
  5. IExecuteResult result = this.ExecuteMethodCall(this,  
  6. ((MethodInfo)(MethodInfo.GetCurrentMethod())), param1);  
  7. return ((int)(result.ReturnValue));  

我们需要时,直接调用就可以了,例如:

  1. int count = db.CustomersCountByRegion("WA");  
  2. Console.WriteLine(count); 

语句描述:这个实例使用Linq存储过程返回在“WA”地区的客户数。

2.单一结果集

从数据库中返回行集合,并包含用于筛选结果的输入参数。 当我们执行返回行集合的存储过程时,会用到结果类,它存储从存储过程中返回的结果。

下面的示例表示一个存储过程,该Linq存储过程返回客户行并使用输入参数来仅返回将“London”列为客户城市的那些行的固定几列。 

  1. ALTER PROCEDURE [dbo].[Customers By City]  
  2. -- Add the parameters for the stored procedure here  
  3. (@param1 NVARCHAR(20))  
  4. AS  
  5. BEGIN  
  6. -- SET NOCOUNT ON added to prevent extra result sets from  
  7. -- interfering with SELECT statements.  
  8. SET NOCOUNT ON;  
  9. SELECT CustomerID, ContactName, CompanyName, City from   
  10. Customers as c where c.City=@param1  
  11. END 

拖到O/R设计器内,它自动生成了以下代码段:

  1. [Function(Name="dbo.[Customers By City]")]  
  2. public ISingleResult<Customers_By_CityResult> Customers_By_City(  
  3. [Parameter(DbType="NVarChar(20)")] string param1)  
  4. {  
  5. IExecuteResult result = this.ExecuteMethodCall(this, (  
  6. (MethodInfo)(MethodInfo.GetCurrentMethod())), param1);  
  7. return ((ISingleResult<Customers_By_CityResult>)  
  8. (result.ReturnValue));  

我们用下面的代码调用:

  1. ISingleResult<Customers_By_CityResult> result =  
  2. db.Customers_By_City("London");  
  3. foreach (Customers_By_CityResult cust in result)  
  4. {  
  5. Console.WriteLine("CustID={0}; City={1}", cust.CustomerID,  
  6. cust.City);  

语句描述:这个实例使用Linq存储过程返回在伦敦的客户的 CustomerID和City。

【编辑推荐】

  1. LINQ to DataSet查询详解
  2. Linq实现XML转换浅谈
  3. Linq to SQL强类型DataContext
  4. Linq SelectMany学习经验
  5. 使用LINQ进行数据转换剖析
责任编辑:佚名 来源: CSDN
相关推荐

2009-09-17 10:04:32

LINQ存储过程

2009-09-17 10:27:55

linq存储过程

2009-09-15 11:08:01

LinQ调用存储过程

2009-09-17 15:22:38

LINQ to SQL

2009-09-17 15:51:39

Linq to sql

2009-09-13 19:24:33

LINQ存储过程

2009-09-17 11:32:52

LINQ调用存储过程

2009-09-17 10:40:23

linq存储过程

2020-11-26 10:33:44

MySQL存储函数

2021-10-15 06:43:11

数据库存储过程

2009-09-15 15:45:00

Linq联合查询

2009-07-08 17:17:16

JDBC调用存储过程

2011-07-19 17:33:53

存储过程javaibatis

2009-09-11 15:12:26

LINQ执行存储过程

2011-08-23 10:14:09

JDBC更新计数行调用存储过程SQL Server

2011-05-18 10:07:13

oracle存储

2010-03-30 13:19:57

Oracle存储

2009-09-18 14:51:19

LINQ TO SQL

2009-09-08 17:27:18

LINQ to Dat

2010-05-07 13:03:01

Oracle通过存储过
点赞
收藏

51CTO技术栈公众号