博客
关于我
16.翻译系列:EF 6 Code -First中使用存储过程【EF 6 Code-First系列】
阅读量:411 次
发布时间:2019-03-06

本文共 1621 字,大约阅读时间需要 5 分钟。

EF 6 Code-First系列文章目录

在开发EF 6 Code-First时,存储过程的配置是一个核心任务。以下是一系列关于EF 6存储过程配置的内容,帮助开发者更好地理解和应用。


1. 存储过程的基础配置

当使用 SaveChanges() 方法时,EF 6能够通过定义存储过程来执行增删改查操作。以下将基于 Student 实体,详细介绍如何创建和配置存储过程。


2. 默认存储过程的配置

EF 6 提供了一个简便的方法来为实体配置默认的存储程序。你可以通过在 OnModelCreating 方法中使用 MapToStoredProcedures() 来启用这一功能。

public class SchoolContext : DbContext{    protected override void OnModelCreating(DbModelBuilder modelBuilder)    {        modelBuilder.Entity
() .MapToStoredProcedures(); }}

3. 自定义存储过程的配置

EF 6 允许开发者为实体定义自定义存储程序。以下是一个示例,展示如何为 Student 实体定义三个存储程序:Student_InsertStudent_UpdateStudent_Delete

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") ) );}

4. 为所有实体配置存储程序

如果你希望为所有实体自动配置存储程序,可以在 OnModelCreating 方法中使用以下代码。

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

5. 存储程序的局限性

在使用EF 6存储程序时,需要注意以下几点:

  • Fluent API 限制:仅通过Fluent API可以配置存储程序,数据注解特性无法实现存储程序映射。
  • CUD 操作要求:如果要执行增删改操作,必须为每个实体定义对应的插入、更新和删除存储程序。

  • 通过以上方法,开发者可以灵活地配置EF 6存储程序,充分发挥其强大功能。

    转载地址:http://zvxkz.baihongyu.com/

    你可能感兴趣的文章
    NPOI设置单元格格式
    查看>>
    Npp删除选中行的Macro录制方式
    查看>>
    NR,NF,FNR
    查看>>
    nrf24l01+arduino
    查看>>
    nrf开发笔记一开发软件
    查看>>
    nrm —— 快速切换 NPM 源 (附带测速功能)
    查看>>
    nrm报错 [ERR_INVALID_ARG_TYPE]
    查看>>
    NS3 IP首部校验和
    查看>>
    NSDateFormatter的替代方法
    查看>>
    NSError 的使用方法
    查看>>
    NSGA-Ⅲ源代码
    查看>>
    nsis 安装脚本示例(转)
    查看>>
    NSJSON的用法(oc系统自带的解析方法)
    查看>>
    nslookup 的基本知识与命令详解
    查看>>
    NSOperation基本操作
    查看>>
    NSRange 范围
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NSURLSession下载和断点续传
    查看>>
    NSUserdefault读书笔记
    查看>>
    NS图绘制工具推荐
    查看>>