16.翻译系列:EF 6 Code -First中使用存储过程【EF 6 Code-First系列】

原文连接:https://www.entityframeworktutorial.net/entityframework6/code-first-insert-update-delete-stored-procedure-mapping.aspxhtml

 

EF 6 Code-First系列文章目录:数据库

 

 

当SaveChanges方法被调用的时候,EF 6  能够用来建立并使用增删改存储过程。app

咱们来为下面的Student实体,建立增删改存储过程。ide

class Student { public int StudentId { get; set; } public string StudentName { get; set; } public DateTime DoB { get; set; } }

使用MapToStoredProcedures()方法,为实体配置默认的存储过程。测试

public class SchoolContext: DbContext { protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Entity<Student>() .MapToStoredProcedures(); } public DbSet<Student> Students { get; set; } }

EF API将会为Student实体建立Student_InsertStudent_Update 和Student_Delete存储过程。ui

 

 Student_Insert和Student_Update存储过程包含Student实体的全部属性的参数,Student_Delete存储过程仅仅包含Student的主键属性StudentID一个参数:spa

CREATE PROCEDURE [dbo].[Student_Insert] @StudentName [nvarchar](max), @DoB [datetime] AS BEGIN INSERT [dbo].[Students]([StudentName], [DoB]) VALUES (@StudentName, @DoB) DECLARE @StudentId int SELECT @StudentId = [StudentId] FROM [dbo].[Students] WHERE @@ROWCOUNT > 0 AND [StudentId] = scope_identity() SELECT t0.[StudentId] FROM [dbo].[Students] AS t0 WHERE @@ROWCOUNT > 0 AND t0.[StudentId] = @StudentId END CREATE PROCEDURE [dbo].[Student_Update] @StudentId [int], @StudentName [nvarchar](max), @DoB [datetime] AS BEGIN UPDATE [dbo].[Students] SET [StudentName] = @StudentName, [DoB] = @DoB WHERE ([StudentId] = @StudentId) END CREATE PROCEDURE [dbo].[Student_Delete] @StudentId [int] AS BEGIN DELETE [dbo].[Students] WHERE ([StudentId] = @StudentId) END

 

为实体映射自定义的存储过程.net

 

EF6容许你使用本身的存储过程,你能够像下面这样进行配置,下面的代码为Student实体,映射了一个自定义的存储过程。翻译

protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Entity<Student>() .MapToStoredProcedures(p => p.Insert(sp => sp.HasName("sp_InsertStudent").Parameter(pm => pm.StudentName, "name").Result(rs => rs.StudentId, "Id")) .Update(sp => sp.HasName("sp_UpdateStudent").Parameter(pm => pm.StudentName, "name")) .Delete(sp => sp.HasName("sp_DeleteStudent").Parameter(pm => pm.StudentId, "Id")) ); }

在上面的例子中,Student实体映射了三个存储过程,sp_InsertStudent、sp_UpdateStudent、以及sp_DeleteStudent.固然一样对存储过程的参数进行了配置。code

 

为全部实体配置存储过程

 

你能够使用下面的代码,为全部实体配置存储过程。

protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Types().Configure(t => t.MapToStoredProcedures()); }

 

局限性

  • 仅仅只有Fluent API才能被用来映射存储过程。EF 6中的数据注解特性,是不能映射存储过程的。
  • 若是你想使用CUD操做,你就必须为实体映射Insert,Update以及Delete存储过程。仅仅是映射其中一个,是不被容许的。
相关文章
相关标签/搜索