【实习】刚入职,公司要求完成两个任务,任务要求使用存储过程和事务,其中一个问题要获取存储过程的查询结果集。经过多方查找和自己的实践,终于找到了方法。这里记录一下。

看到的这篇文章中给出的例子是查询单个表的所有数据,但是我的要求是多表查询并获取其中的几个字段。而且我是使用POCO(POCO是指Plain Old Class Object,也就是最基本的CLRClass),还是和示例有诸多不同。这里我结合文章中的示例和自己的尝试,解决了这个问题

首先建立存储过程 可以看到 这里我只需要sn.jewelry_type ,tr.[History Sign2] ,SUM(his.[Actual_Selling_Price]) AS Summary这三个字段

CREATE PROCEDURE dbo.SP_Branch_Month_Sells
@branchCode INT,
@transactionDate DATE
AS
SELECT
sn.jewelry_type AS JewelryType,
tr.[History Sign2] AS HistorySign2,
SUM(his.[Actual_Selling_Price]) AS Summary FROM dbo.History his
INNER JOIN dbo.[stock nature] sn
ON his.[Stock Type] = sn.stock_type
AND his.[Stock Group] = sn.stock_group
INNER JOIN dbo.[History Tran Code] tr
ON his.[Tran Code] = tr.[History Tran Code]
WHERE his.[Branch Code From] = @branchCode
AND sn.[jewelry_type] IN ( 1, 2, 3 )
AND tr.[History Sign2] IN ( 2, 7, 8, -2, -7, -8 )
AND DateDiff(mm,his.[Transaction Date],@transactionDate)=0
GROUP BY sn.jewelry_type, tr.[History Sign2]
GO

然后根据这三个字段建立对应的实体类和配置类,虽然在数据库中并没有对应的表,这里的实体类只是作为存储过程的结果集的对应实体

public class SellEntity
{
public Int16 JewelryType { get; set; }
public Int16 HistorySign2 { get; set; }
public decimal Summary { get; set; }
} public class SellConfig:EntityTypeConfiguration<SellEntity>
{
public SellConfig()
{
//EF 需要每个表都有一个键,这里的JewelryType并没有实际键的意义,只是为满足EF的要求
HasKey(u => u.JewelryType);
Property(u => u.JewelryType).HasColumnName("JewelryType");
Property(u => u.HistorySign2).HasColumnName("HistorySign2"); }
}

然后就可以使用EF调用存储过程来获取结果集并和实体类对应起来,注意这里我使用了DTO,

public class SellDTO
{
public int JewelryType { get; set; }
public int HistorySign2 { get; set; }
public decimal Summary { get; set; }
} public SellDTO[] GetSells(int branchCode, DateTime monthDate)
{
using(TrainContext ctx = new TrainContext())
{
var paramters = new SqlParameter[]
{
new SqlParameter("branchCode",SqlDbType.Int)
{ Value=branchCode},
new SqlParameter("transactionDate", SqlDbType.Date)
{
Value =monthDate.ToShortDateString()
}
};
//EO转换成DTO
return ctx.Sells.SqlQuery("EXEC dbo.SP_Branch_Month_Sells @branchCode,@transactionDate)", paramters)
.ToList().Select(u=>new SellDTO()
{
JewelryType = u.JewelryType,
HistorySign2 = u.HistorySign2,
Summary =
u.Summary
}).ToArray();

}
}

这里是DAL层的代码,BLL层只是对参数做转发

 public class SellBLL
{
public SellDTO[] GetSellByMonthAndBranchCode(int branchCode, DateTime monthDate)
{
var sellDAL = new SellDAL();
return sellDAL.GetSells(branchCode, monthDate);
}
}

下面进行单元测试:

[TestClass]
public class SellTests
{
[TestMethod]
public void GetSellByMonthAndBranchCodeTest()
{
SellBLL sellBLL = new SellBLL(); var sells = sellBLL.GetSellByMonthAndBranchCode(, DateTime.Today.AddDays(-));
}
}

测试结果

拿到结果集 和直接在数据库查询的结果一致。

成功

使用EntityFramework调用存储过程并获取存储过程返回的结果集的更多相关文章

  1. EF中执行存储过程,获取output返回值

    EF不能直接支持执行存储过程,于是使用转化成执行SQL语句的形式,却怎么也获取不到output的值,折腾的好久,终于解决了,分享下曲折的经历: public int AddVote(int title ...

  2. 连接sqlServer数据库&jpa调用存储过程Java获取存储过程返回的多个结果集JAVA调用sqlserver存储过程的实现(返回多个结果集的实现)jdbc多结果集(getMoreResults)

    存储过程: BEGIN select * from teacher; SELECT * FROM student; END public Object GetMyBOProjectProductLis ...

  3. [Java]在xp系统下java调用wmic命令获取窗口返回信息无反应(阻塞)的解决方案

    背景:本人写了一段java代码,调用cmd命令“wmic ...”来获取系统cpu.mem.handle等资源信息.在win7操作系统下运行没有问题,在xp系统下却发现读取窗口反馈信息时无反应(阻塞) ...

  4. Shell $?获取函数返回值或者上一个命令的退出状态

    Shell $?获取函数返回值或者上一个命令的退出状态 来自:互联网 时间:2021-01-12 阅读:2 $? 是一个特殊变量,用来获取上一个命令的退出状态,或者上一个函数的返回值. 所谓退出状态, ...

  5. Yii2.0调用sql server存储过程并获取返回值

    1.首先展示创建sql server存储过程的语句,创建一个简单的存储过程,测试用. SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE P ...

  6. C#获取存储过程返回值和输出参数值的方法

    //转自网络,先留个底 1.获取Return返回值 //存储过程 //Create PROCEDURE MYSQL // @a int, // @b int //AS // return @a + @ ...

  7. C#调用SQL中的存储过程中有output参数,存储过程执行过程中返回信息

      C#调用SQL中的存储过程中有output参数,类型是字符型的时候一定要指定参数的长度.不然获取到的结果总是只有第一字符.本人就是由于这个原因,折腾了很久.在此记录一下,供大家以后参考! 例如: ...

  8. SqlDataReader 获取存储过程返回值

    编写存储过程,获取不到返回值 附上代码: SqlDataReader reader = null;// totalRecords = ; try { SqlConnectionHolder conne ...

  9. SQL server 存储过程 C#调用Windows CMD命令并返回输出结果 Mysql删除重复数据保留最小的id C# 取字符串中间文本 取字符串左边 取字符串右边 C# JSON格式数据高级用法

    create proc insertLog@Title nvarchar(50),@Contents nvarchar(max),@UserId int,@CreateTime datetimeasi ...

随机推荐

  1. mysql数据按条件导出

    仅导出部分数据: mysqldump -hlocalhost -uuser -p --skip-triggers --no-create-info dbname tbname -w "id ...

  2. CSS3 nth-of-type(n)选择器 last-of-type选择器 nth-last-of-type(n)选择器 CSS3 only-child选择器 only-of-type选择器

    CSS3 nth-of-type(n)选择器 “:nth-of-type(n)”选择器和“:nth-child(n)”选择器非常类似,不同的是它只计算父元素中指定的某种类型的子元素.当某个元素中的子元 ...

  3. ArrayList,Vector, LinkedList的存储性能和特性?

    ArrayList,Vector, LinkedList的存储性能和特性? ArrayList 采用的是数组形式来保存对象的,这种方式将对象放在连续的位置中,所以最大的缺点就是插入或删除时非常麻烦. ...

  4. TFRecords文件的生成和读取(1)

    参考:https://blog.csdn.net/u012222949/article/details/72875281 参考:https://blog.csdn.net/chengshuhao199 ...

  5. Django ormmodel模型字段参考文章

    Model 字段参考 (Model field reference)¶ 本文档包含所有 字段选项 (field options) 的内部细节和 Django 已经提供的 field types . 参 ...

  6. eclipse 报错:One or more constraints have not been satisfied.

    接受 我有同样的问题.在我的maven项目中添加速度依赖关系后,我在标记选项卡中得到相同的错误.然后我注意到maven项目创建的web.xml文件具有servlet2.3模式.当我将其更改为servl ...

  7. Cluster基础(二):ipvsadm命令用法、部署LVS-NAT集群、部署LVS-DR集群

    一.ipvsadm命令用法 目标: 准备一台Linux服务器,安装ipvsadm软件包,练习使用ipvsadm命令,实现如下功能: 使用命令添加基于TCP一些的集群服务 在集群中添加若干台后端真实服务 ...

  8. PHP 使用 PHPExcel 库生成 Excel 文件

    PHPExcel 是用来操作Office Excel 文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言.可以使用它来读取.写入不同格式的电子表格,如 Excel (BIFF) .xls ...

  9. PHP实现多服务器SESSION共享

    为什么要session共享? 现在稍微大一点的网站基本上都有好几个子域名,比如www.feiniu.com, search.feiniu.com, member.feiniu.com,这些网站如果需要 ...

  10. 洛谷P1441 砝码称重(搜索,dfs+bitset优化)

    洛谷P1441 砝码称重 \(n\) 的范围为 \(n \le 20\) ,\(m\) 的范围为 \(m \le 4\) . 暴力遍历每一种砝码去除情况,共有 \(n^m\) 种情况. 对于剩余砝码求 ...