文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Linq结果集形状怎么实现

2023-06-17 22:20

关注

这篇文章主要介绍“Linq结果集形状怎么实现”,在日常操作中,相信很多人在Linq结果集形状怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linq结果集形状怎么实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

当存储过程可以返回多个Linq结果集形状时,返回类型无法强类型化为单个投影形状。尽管 LINQ to SQL 可以生成所有可能的投影类型,但它无法获知将以何种顺序返回它们。 ResultTypeAttribute 属性适用于返回多个结果类型的存储过程,用以指定该过程可以返回的类型的集合。

在下面的 SQL 代码示例中,Linq结果集形状取决于输入(param1 = 1或param1 = 2)。我们不知道先返回哪个投影。

ALTER PROCEDURE [dbo].[SingleRowset_MultiShape]  -- Add the parameters for the stored procedure here  (@param1 int )  AS  BEGIN  -- SET NOCOUNT ON added to prevent extra result sets from  -- interfering with SELECT statements.  SET NOCOUNT ON;  if(@param1 = 1)  SELECT * from Customers as c where c.Region = 'WA' else if (@param1 = 2)  SELECT CustomerID, ContactName, CompanyName from   Customers as c where c.Region = 'WA' END

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

[Function(Name="dbo.[Whole Or Partial Customers Set]")]  public ISingleResult<Whole_Or_Partial_Customers_SetResult>   Whole_Or_Partial_Customers_Set([Parameter(DbType="Int")]   System.Nullable<int> param1)  {  IExecuteResult result = this.ExecuteMethodCall(this,   ((MethodInfo)(MethodInfo.GetCurrentMethod())), param1);  return ((ISingleResult<Whole_Or_Partial_Customers_SetResult>)  (result.ReturnValue));  }

但是,VS2008会把多结果集存储过程识别为单结果集的存储过程,默认生成的代码我们要手动修改一下,要求返回多个结果集,像这样:

[Function(Name="dbo.[Whole Or Partial Customers Set]")]  [ResultType(typeof(WholeCustomersSetResult))]  [ResultType(typeof(PartialCustomersSetResult))]  public IMultipleResults Whole_Or_Partial_Customers_Set([Parameter  (DbType="Int")] System.Nullable<int> param1)  {  IExecuteResult result = this.ExecuteMethodCall(this,   ((MethodInfo)(MethodInfo.GetCurrentMethod())), param1);  return ((IMultipleResults)(result.ReturnValue));  }

我们分别定义了两个分部类,用于指定返回的类型。这样就可以使用了,下面代码直接调用,分别返回各自的结果集合。

//返回全部Customer结果集  IMultipleResults result = db.Whole_Or_Partial_Customers_Set(1);  IEnumerable<WholeCustomersSetResult> shape1 =  result.GetResult<WholeCustomersSetResult>();  foreach (WholeCustomersSetResult compName in shape1)  {  Console.WriteLine(compName.CompanyName);  }  //返回部分Customer结果集  result = db.Whole_Or_Partial_Customers_Set(2);  IEnumerable<PartialCustomersSetResult> shape2 =  result.GetResult<PartialCustomersSetResult>();  foreach (PartialCustomersSetResult con in shape2)  {  Console.WriteLine(con.ContactName);  }

语句描述:这个实例使用存储过程返回“WA”地区中的一组客户。返回的Linq结果集形状取决于传入的参数。如果参数等于 1,则返回所有客户属性。如果参数等于2,则返回ContactName属性。

到此,关于“Linq结果集形状怎么实现”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯