.net core EF Core调用存储过程的方式

网络编程 2021-07-04 22:41www.168986.cn编程入门
这篇文章主要给大家介绍了关于. core EF Core调用存储过程的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用. core EF Core具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化来一起学习学习吧

前言

在这里,我们将尝试去学习一下 . core EF Core 中调用存储过程。

我们知道,EF Core 是不支持直接调用存储过程的,那它又提供了什么样的方式去执行存储过程呢?有如下方法

1、FromSql,

DbSet<TEntity>.FromSql()

2、执行SQl命令

DbContext.Database.ExecuteSqlCommand()

,这两种方式都有局限性

1、FromSql方式的结果一定要是实体类型,就是数据库表映射的模型。这意味着,执行存储过程返回的结果一定是跟数据库表相关的所有字段;

2、FromSql方式的结果不能有关联关系数据。这就相当于不能 join ,也返回不了 join 的关联表的数据。

3、ExecuteSqlCommand执行插入、更新跟删除的存储过程不能直接映射到实体(EF Core不支持嘛,在讲 EF 跟 EF Core 的区别时已经很清晰了),所以,CUD 方法不能直接调用 SaveChanges 方法。

我们来试试演示一下

(1)准备一个存储过程,一般为了方便,直接就是 DB-First,执行以下的 SQL 脚本就OK了

USE [Library]
GO

SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE PROCEDURE [dbo].[proc_getbooks]
   @name nvarchar(50)
  AS
  BEGIN
   SET NOCOUNT ON;
   select  from books where name like @name +'%'
  END
GO

当创建好了这个有传参的有返回结果的存储过程的时候,数据库在可编程性下就有一个存储过程了(这个数据库是我专门用来做demo的)

(2)用 FromSql 调用存储过程,由上面就可以知道它是 DbSet 的方法,而 DbSet 是可以执行原生的 sql 语句去查询底层的数据库。同样,使用 DbSet 可以执行存储过程,从而返回实体类型,但就是具有上面所说的局限性罢了。

//用 FromSql 调存储过程
   var name = "C";

   var books = _context.Books
      .FromSql($"proc_getbooks {name}")
      .ToList();

   //or 使用 exec 关键字调用存储过程
   //var books = _context.Books.FromSql($"exec proc_getbooks {name}").ToList();

   //or 使用 SqlParameter 实例进行参数的插入
   //var param = new SqlParameter()
   //{
   // ParameterName = "@name",
   // SqlDbType = System.Data.SqlDbType.NVarChar,
   // Direction = System.Data.ParameterDirection.Input,
   // Size = 50,
   // Value = name
   / 

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by