关于EF调用存储过程碰到的问题解决过程
来源:互联网 发布:黑社会2知乎 编辑:程序博客网 时间:2024/06/06 09:31
网上有人说不建议在EF中用存储过程,或许他是对的。
1. 调用mysql存储过程,存储过程为返回两个结果集
CREATE PROCEDURE pro_prevnextrecord(IN `iCmsID` varchar(50),IN `iCateID` varchar(50))BEGINDROP TABLE IF EXISTS tmp1; CREATE TEMPORARY TABLE tmp1(`ID` VARCHAR(50) NOT NULL,`Num` INTEGER NOT NULL,PRIMARY KEY (`ID`))ENGINE=MyISAM DEFAULT CHARSET=utf8;INSERT INTO tmp1(ID,Num)SELECT id,row_no FROM (SELECT a.id,a.CategoryID,a.Sysid,(@row_num:=@row_num+1) as row_no from cmscontent a,(select(@row_num:=0)) b ORDER BY a.categoryID,a.Sysid desc) c WHERE c.CategoryID=iCateID; SELECT (@Num :=Num) as mynum FROM tmp1 WHERE id=iCmsID;SELECT CONCAT('productdetail?ID=',a.id) AS LinkUrl,CASE WHEN @Num<a.Num then '下一张' ELSE '上一张' END AS LinkTextFROM tmp1 a LEFT JOIN cmscontent b ON a.id=b.id WHERE a.Num=@Num-1 or a.Num=@Num+1 ORDER BY a.Num;END
2. 在edmx生成存储过程函数方法.
现在双击edmx文件,展开视图界面右键找到从数据库更新模型,可以百度这里操作存储过程的资料。
如果在DbContext继承类里没有自动生成相应函数,则再次双击edmx文件,在展开的视图界面右键找到模型浏览器,单击它。在Store节点下存储过程/函数菜单里面可以发现所调用的存储过程名称,选中右键添加函数导入,返回复杂内容类型,点确定。
3. 选择edmx使用xml方式修改
在相应节点下修改成以下内容:
<FunctionImport Name="pro_prevnextrecord" > <ReturnType Type="Collection(lab_equiModel.prevNextRecordResult1)"></ReturnType> <ReturnType Type="Collection(lab_equiModel.prevNextRecordResult2)"></ReturnType> <Parameter Name="iCmsID" Mode="In" Type="String" /> <Parameter Name="iCateID" Mode="In" Type="String" /> </FunctionImport>
<ComplexType Name="prevNextRecordResult1" > <Property Name="mynum" Type="Int32" /> </ComplexType> <ComplexType Name="prevNextRecordResult2" > <Property Name="LinkUrl" Type="String" MaxLength="70" Unicode="true" FixedLength="false" /> <Property Name="LinkText" Type="String" MaxLength="10" Unicode="true" FixedLength="false" /> </ComplexType>
<FunctionImportMapping FunctionImportName="pro_prevnextrecord" FunctionName="lab_equiModel.Store.pro_prevnextrecord" > <ResultMapping> <ComplexTypeMapping TypeName="lab_equiModel.prevNextRecordResult1"> <ScalarProperty Name="mynum" ColumnName="mynum" /> </ComplexTypeMapping> </ResultMapping> <ResultMapping> <ComplexTypeMapping TypeName="lab_equiModel.prevNextRecordResult2"> <ScalarProperty Name="LinkUrl" ColumnName="LinkUrl" /> <ScalarProperty Name="LinkText" ColumnName="LinkText" /> </ComplexTypeMapping> </ResultMapping> </FunctionImportMapping>
4. 运用T4模板
在tt扩展名文件的属性里面,检查自定义工具命名空间,空白的话就写上自己需要的命名空间。然后在其右键菜单上运行自定义工具。这里能自动补全返回集合类的各个字段。
5. 返回多记录集
在logic代码层,设置函数如下:
public List<prevNextRecordResult2> GetPrevnextrecord(string iCmsID, string iCateID) { var result2 = db.pro_prevnextrecord(iCmsID, iCateID).GetNextResult<prevNextRecordResult2>(); return result2.ToList(); }调用结果集在第二张表,则用GetNextResult
6.参考文章
http://www.codeproject.com/Articles/675933/Returning-Multiple-Result-Sets-from-an-Entity-Fram
https://q.cnblogs.com/q/56836/
http://blog.csdn.net/leftfist/article/details/39226243
http://www.cnblogs.com/chenliyang/p/6633534.html
0 0
- 关于EF调用存储过程碰到的问题解决过程
- EF中关于存储过程的操作
- EF框架调用存储过程
- EF调用存储过程、函数
- EF调用存储过程、函数
- EF操作存储过程调用
- 关于存储过程的调用
- MVC之EF(调用存储过程的分页)
- EF和LINQ 调用存储过程
- 使用EF来调用存储过程
- EF 存储过程(下)
- EF 存储过程(上)
- EF框架下调用 调用Oracle 存储过程
- 关于oracle的存储过程以及调用。
- 关于SPRING调用ORACLE的存储过程
- mysql存储过程一次连接多次调用失败的问题解决
- EF core 2.0 调用MySql数据库存储过程
- 关于hibernate调用存储过程
- 其中的opacity 和 rgba设置背景透明度的用法和区别
- OGRE学习系列二:基础教程介绍
- 角谷定理
- 文件夹和其下的文件获取最高权限
- jQuery高级之能力检测
- 关于EF调用存储过程碰到的问题解决过程
- 能力测试
- 文章标题
- 内容社区如何做文章排序及StackOverflow问答排名算法
- JQuery 取消时间冒泡
- RxJava1.x从入门到放弃再到RxJava 2.x(二)
- R语言做文本挖掘 Part1安装依赖包
- What Kind of Friends Are You?
- 取消 超链接 跳转