EF6学习笔记十一:调用、自动生成存储过程

Wesley13
• 阅读 611

要专业系统地学习EF前往《你必须掌握的Entity Framework 6.x与Core 2.0》这本书的作者(汪鹏,Jeffcky)的博客:https://www.cnblogs.com/CreateMyself/

前面说到EF中的原始查询,就是写SQL语句执行

那么还有存储过程的调用也是通过那几个方法来的

调用查询数据的存储过程使用:ctx.Database.SqlQuery()  或者 ctx.DbSet.SqlQuery()

调用Insert、Update、Delete操作的存储过程使用:ExceuteSqlCommand()或者ExceuteSqlCommandAsync()

调用存储过程

我们先手动地添加一个存储过程:select * from tb_products

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

create procedure GetProducts
as
begin
set nocount on;
select * from tb_Products;
set nocount off;
end
go

View Code

紧接着调用它,可以

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

var res = ctx.Database.SqlQuery<Product>("dbo.GetProducts");
Console.WriteLine(JsonConvert.SerializeObject(res,set));

View Code

然后再创建一个存储过程:select id,name from tb_products

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

create procedure GetProducts2
as
begin
select id,[name] from tb_Products
end
go

View Code

接收类型的属性数量和返回数据集的字段数量不一致,报错。得自己另外定义类型去接收

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

var res = ctx.Database.SqlQuery<Product>("dbo.getproducts2");
Console.WriteLine(JsonConvert.SerializeObject(res));
//  未经处理的异常:  System.Data.Entity.Core.EntityCommandExecutionException: The data reader is incompatible with the specified 'CodeFirstNamespace.Product'. A member of the type, 'Price', does not have a corresponding column in the data reader with the same name.

View Code

 来看看带参数的存储过程,在方法中该怎么写

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

-- 传递参数,name
create procedure GetProductsByName
(
@name as nvarchar(50)
)
as
begin
select *from tb_Products where [Name] =@name;
end
go

--  执行
exec GetProductsByName '砖头'
go

View Code

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

// 一个参数name
var parameter = new SqlParameter("@name","水泥");
var res = ctx.Database.SqlQuery<Product>("dbo.getproductsByName @name",parameter);
Console.WriteLine(JsonConvert.SerializeObject(res));
//  [{"Order":null,"Name":"水泥","Price":50.00,"Unit":"袋","FK_Order_Id":"469b82be-8139-4e67-b566-5b2b5f6d838d","Id":"d951e96d-a581-4f87-a567-bedb4c24eca3","AddTime":"2019-01-15T10:28:00.653"}]

View Code

 来看看多个参数的存储过程

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

--  两个参数,id,price
create procedure GetProducts3
(
@id as nvarchar(36), 
@price as decimal(18,2)
)
as
begin 
select * from tb_Products where id =@id and Price = @price
end
go

View Code

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

//  两个参数
var parameterList = new List<SqlParameter>
     {
            new SqlParameter(){ ParameterName="@id",SqlDbType = System.Data.SqlDbType.NVarChar,Value ="6495f22b-f1ef-4bd2-b81e-c49eaf6e2f21"},
            new SqlParameter(){ ParameterName="@price",SqlDbType=System.Data.SqlDbType.Decimal,Value=5}
       };
var parameterArr = parameterList.ToArray();
var res = ctx.Database.SqlQuery<Product>("dbo.getproducts3 @id,@price",parameterArr);
Console.WriteLine(JsonConvert.SerializeObject(res));
//[{"Order":null,"Name":"苹果","Price":5.00,"Unit":"斤","FK_Order_Id":"e18757db-1db8-4f7f-b702-79138709b304","Id":"6495f22b-f1ef-4bd2-b81e-c49eaf6e2f21","AddTime":"2019-01-15T10:35:03.36"}]
// 简直没有问题

View Code

 上面的都是执行的查询操作,来看看添加操作的存储过程,我们使用ExcuteSqlCommand()方法

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

--  添加数据
create procedure AddProduct
(
@name as nvarchar(50),
@price as decimal(18,2),
@unit as nvarchar(10)
)
as
begin
insert into tb_Products values(newid(),@name,@price,'469b82be-8139-4e67-b566-5b2b5f6d838d',getdate(),@unit)
end
go

View Code

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

var parameterList = new List<SqlParameter>
{
    new SqlParameter(){ ParameterName="@name",SqlDbType = System.Data.SqlDbType.NVarChar,Value ="花生"},
    new SqlParameter(){ ParameterName="@price",SqlDbType = System.Data.SqlDbType.Decimal,Value = 4.4},
    new SqlParameter(){ ParameterName ="@unit",SqlDbType = System.Data.SqlDbType.NVarChar,Value="斤"}
};
var paraArr = parameterList.ToArray();
var res = ctx.Database.ExecuteSqlCommand("dbo.addproduct @name,@price,@unit", paraArr);
Console.WriteLine(res);  //  result : 1

View Code

EF自动生成存储过程

 上面的存储过程都是手动添加,现在我们在OnModelCreating方法中写配置,让它自动添加存储过程

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

modelBuilder.Entity<Order>().MapToStoredProcedures();

View Code

这样他会给你生成三个存储过程

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

public partial class jinshantest4 : DbMigration
    {
        public override void Up()
        {
            CreateStoredProcedure(
                "dbo.Order_Insert",
                p => new
                    {
                        Id = p.String(maxLength: 128),
                        OrderNO = p.String(),
                        Description = p.String(),
                        AddTime = p.DateTime(),
                    },
                body:
                    @"INSERT [dbo].[tb_Orders]([Id], [OrderNO], [Description], [AddTime])
                      VALUES (@Id, @OrderNO, @Description, @AddTime)"
            );
            
            CreateStoredProcedure(
                "dbo.Order_Update",
                p => new
                    {
                        Id = p.String(maxLength: 128),
                        OrderNO = p.String(),
                        Description = p.String(),
                        AddTime = p.DateTime(),
                    },
                body:
                    @"UPDATE [dbo].[tb_Orders]
                      SET [OrderNO] = @OrderNO, [Description] = @Description, [AddTime] = @AddTime
                      WHERE ([Id] = @Id)"
            );
            
            CreateStoredProcedure(
                "dbo.Order_Delete",
                p => new
                    {
                        Id = p.String(maxLength: 128),
                    },
                body:
                    @"DELETE [dbo].[tb_Orders]
                      WHERE ([Id] = @Id)"
            );
            
        }
        
        public override void Down()
        {
            DropStoredProcedure("dbo.Order_Delete");
            DropStoredProcedure("dbo.Order_Update");
            DropStoredProcedure("dbo.addOrder");
        }
    }

View Code

也可以对它进行详细配置,比如我指定insert存储过程的名称为“orderAdd” 

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

modelBuilder.Entity<Order>().MapToStoredProcedures(x => x.Insert(a => a.HasName("addOrder")));

View Code

跟新后,可以看到存储过程都添加 成功了

 EF6学习笔记十一:调用、自动生成存储过程

最后来调用一个EF为我们创建的存储过程

EF6学习笔记十一:调用、自动生成存储过程 EF6学习笔记十一:调用、自动生成存储过程

//  添加一个订单
var parameterList = new List<SqlParameter>
{
    new SqlParameter{ ParameterName="@Id",SqlDbType = System.Data.SqlDbType.NVarChar,Value = Guid.NewGuid().ToString()},
    new SqlParameter{ ParameterName="@OrderNO",SqlDbType = System.Data.SqlDbType.NVarChar,Value ="order435435"},
    new SqlParameter{ ParameterName="@Description",SqlDbType = System.Data.SqlDbType.NVarChar,Value="description4364537ryrtey"},
    new SqlParameter{ ParameterName="@AddTime",SqlDbType = System.Data.SqlDbType.DateTime,Value =DateTime.Now}
};
var paraArr = parameterList.ToArray();
var res = ctx.Database.ExecuteSqlCommand("dbo.addOrder @Id,@OrderNO,@Description,@AddTime",paraArr);
Console.WriteLine(res);  //  result:1

View Code

EF6学习笔记十一:调用、自动生成存储过程

可以的

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
3年前
EntityFramework之原始查询及性能优化(六)
前言在EF中我们可以通过Linq来操作实体类,但是有些时候我们必须通过原始sql语句或者存储过程来进行查询数据库,所以我们可以通过EFCodeFirst来实现,但是SQL语句和存储过程无法进行映射,于是我们只能手动通过上下文中的SqlQuery和ExecuteSqlCommand来完成。SqlQuerysql语句查询实
Wesley13 Wesley13
3年前
mysql存储过程和自定义函数
存储过程简介SQL语句需要先编辑后执行,而存储过程是一组为了完成特定功能的SQL语句集,经编译后存储过程在数据库中,用户通过制定存储过程的名字并传给参数来调用它。存储过程是可编程的函数,在数据库中创建并保持,可以由SQL和控制结构组成。档想要在不同的应用平台上执行相同的函数,或者封装特定功能时,存储过程是非常有用的,数据库中的存储过程可以看错
Wesley13 Wesley13
3年前
Mysql存储过程
SQL语句需要先编译然后执行,而存储过程(StoredProcedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。存储过程是可编程的函数,在数据库中创建并保存,可以由SQL语句和控制结构组成。当想要在不同的应用程序或平台上执行相同的函数,或者封装特定功能时
Wesley13 Wesley13
3年前
Oracle存储过程
1、定义所谓存储过程(StoredProcedure),就是一组用于完成特定数据库功能的SQL语句集,该SQL语句集经过编译后存储在数据库系统中。在使用时候,用户通过指定已经定义的存储过程名字并给出相应的存储过程参数来调用并执行它,从而完成一个或一系列的数据库操作。2、存储过程的创建Oracle存储过程包含三部分
小万哥 小万哥
11个月前
SQL 算术运算符:加法、减法、乘法、除法和取模的用法
SQLServer中的存储过程什么是存储过程?存储过程是一段预先编写好的SQL代码,可以保存在数据库中以供反复使用。它允许将一系列SQL语句组合成一个逻辑单元,并为其分配一个名称,以便在需要时调用执行。存储过程可以接受参数,使其更加灵活和通用。存储过程语法
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这