本文共 2495 字,大约阅读时间需要 8 分钟。
原文链接:
EF 6 Code-First系列文章目录:
当SaveChanges方法被调用的时候,EF 6 可以用来创建并使用增删改存储过程。
我们来为下面的Student实体,创建增删改存储过程。
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() .MapToStoredProcedures(); } public DbSet Students { get; set; }}
EF API将会为Student实体创建Student_Insert
, Student_Update
和Student_Delete存储过程。
Student_Insert和Student_Update存储过程包含Student实体的所有属性的参数,Student_Delete存储过程仅仅包含Student的主键属性StudentID一个参数:
CREATE PROCEDURE [dbo].[Student_Insert] @StudentName [nvarchar](max), @DoB [datetime]ASBEGIN 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] = @StudentIdENDCREATE PROCEDURE [dbo].[Student_Update] @StudentId [int], @StudentName [nvarchar](max), @DoB [datetime]ASBEGIN UPDATE [dbo].[Students] SET [StudentName] = @StudentName, [DoB] = @DoB WHERE ([StudentId] = @StudentId)ENDCREATE PROCEDURE [dbo].[Student_Delete] @StudentId [int]ASBEGIN DELETE [dbo].[Students] WHERE ([StudentId] = @StudentId)END
为实体映射自定义的存储过程
EF6允许你使用自己的存储过程,你可以像下面这样进行配置,下面的代码为Student实体,映射了一个自定义的存储过程。
protected override void OnModelCreating(DbModelBuilder modelBuilder){ modelBuilder.Entity() .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.当然同样对存储过程的参数进行了配置。
为所有实体配置存储过程
你可以使用下面的代码,为所有实体配置存储过程。
protected override void OnModelCreating(DbModelBuilder modelBuilder){ modelBuilder.Types().Configure(t => t.MapToStoredProcedures());}
局限性
转载地址:http://zvxkz.baihongyu.com/