Linq结果集形状怎么实现
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要介绍"Linq结果集形状怎么实现",在日常操作中,相信很多人在Linq结果集形状怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Linq结果集形状怎么
千家信息网最后更新 2025年01月19日Linq结果集形状怎么实现
这篇文章主要介绍"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 ISingleResultWhole_Or_Partial_Customers_Set([Parameter(DbType="Int")] System.Nullable param1) { IExecuteResult result = this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())), param1); return ((ISingleResult ) (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.Nullableparam1) { IExecuteResult result = this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())), param1); return ((IMultipleResults)(result.ReturnValue)); }
我们分别定义了两个分部类,用于指定返回的类型。这样就可以使用了,下面代码直接调用,分别返回各自的结果集合。
//返回全部Customer结果集 IMultipleResults result = db.Whole_Or_Partial_Customers_Set(1); IEnumerableshape1 = result.GetResult (); foreach (WholeCustomersSetResult compName in shape1) { Console.WriteLine(compName.CompanyName); } //返回部分Customer结果集 result = db.Whole_Or_Partial_Customers_Set(2); IEnumerable shape2 = result.GetResult (); foreach (PartialCustomersSetResult con in shape2) { Console.WriteLine(con.ContactName); }
语句描述:这个实例使用存储过程返回"WA"地区中的一组客户。返回的Linq结果集形状取决于传入的参数。如果参数等于 1,则返回所有客户属性。如果参数等于2,则返回ContactName属性。
到此,关于"Linq结果集形状怎么实现"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
结果
形状
类型
过程
存储
代码
学习
参数
多个
属性
投影
生成
取决于
客户
更多
帮助
实用
接下来
两个
单个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
海康服务器硬盘安装
苏州第三方软件开发哪家便宜
药学就业情况数据库
迷你世界新开服务器
广东工控机与服务器虚拟主机
软件开发过程有几个阶段
软件开发企业怎么做账务
网络安全和云计算产品
深圳联科通网络技术专业怎么样
emobile服务器
ftp客户机和服务器之间建立
网络服务器的安全隐患
ktv服务器怎么重新安装系统
迷你世界有什么服务器
IP网络技术作业
网络安全应当受到注意英语作文
网络安全证书怎么开通
怎么找到数据库引擎
怎么改代理服务器
服务器管理软件报价
细胞壁降解酶数据库
oracle数据库缓慢
网络安全知识进校园横幅
物联网软件开发技术需求
如何查看伊洛纳服务器
长春打车用什么软件开发
平顶山软件开发商家
局网络安全工作实施计划
澳洲 网络安全 工资
连云港网络安全资质申请费用