LINQ调用存储过程的实现方法

开发 后端
在LINQ调用存储过程时,LINQ调用存储过程会自动为返回的结果集生成一个类型,类型的名字是由 SP名+"Result" 组成。

LINQ调用存储过程实现起来一点都不容易,就像其它的存储过程一样,需要很强的逻辑性与实用性。

LINQ调用存储过程时出现的问题被customer问了多次了,我想问题虽小,但可能对大家有帮助,就顺便写下来和大家分享。

问题是这样的,在LINQ调用存储过程时,很多customer不知道怎么去接受返回的结果集。所以很多人就这样做了,当然,看起来是能理解的:

  1. SampleDataContext test = new SampleDataContext();  
  2. IEnumerable retVal = test.sp();   // error here! 

但是在编译时就会出错,报一个类型转换的错误。其实在LINQ调用存储过程时,LINQ调用存储过程会自动为返回的结果集生成一个类型,类型的名字是由 SP名+"Result" 组成。

如SP名是sp,那么生成的类型就是 spResult。而调用SP时所返回的结果集就是 ISingleResult。至于为什么会报类型转换错误呢,很简单,ISingleResult和IEnumerable不能互转。

现在大家应该知道该怎么做了吧?Try下如下代码:

  1. SampleDataContext test = new SampleDataContext();  
  2. ISinlgeResult retValue = test.sp();  
  3. foreach(spResult value in retValue)  
  4. {  
  5.    string field = value.field;  

知道了怎么做还远远不够,建议大家去看看LINQ调用存储过程自动生成的代码。如果有这样的习惯,相信大家很容易就能自己解决问题了。不过LINQ-SQL还有个小bug,如SingleResult所暗示的一样,它还不能为我们生成MultipleResults,如SP中含有两条Select语句时。

【编辑推荐】

  1. 详谈Linq查询结果分析的方法
  2. 简简单单学习Linq查询语法
  3. 详细阐述Linq插入数据的操作方法
  4. 浅析Linq插入数据的实现方法
  5. 简单解决Linq多条件组合问题
责任编辑:阡陌 来源: 博客园
相关推荐

2009-09-15 11:08:01

LinQ调用存储过程

2010-10-29 16:12:51

Oracle存储过程

2009-09-17 10:40:23

linq存储过程

2010-10-09 16:26:59

mysql存储过程

2009-09-11 15:12:26

LINQ执行存储过程

2009-09-17 10:04:32

LINQ存储过程

2012-03-01 13:34:02

Java

2009-09-13 19:24:33

LINQ存储过程

2009-09-09 10:54:52

Linq存储过程返回

2009-09-09 13:18:26

Linq Submit

2009-09-09 09:59:08

Linq调用LoadP

2009-08-06 18:02:22

存储过程

2017-09-04 11:48:56

MybatisOracle存储过程

2009-09-14 16:29:39

LINQ嵌套

2009-09-17 15:51:39

Linq to sql

2009-09-17 15:22:38

LINQ to SQL

2009-09-17 10:27:55

linq存储过程

2009-06-17 10:33:17

Hibernate 存

2011-09-01 13:43:23

VC调用SQL Ser

2010-10-28 10:10:48

oracle存图片
点赞
收藏

51CTO技术栈公众号