LINQ调用存储过程的实现方法
创始人
2024-06-07 08:21:26
0

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多条件组合问题

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...