zoukankan      html  css  js  c++  java
  • 第五章:创建DbContext

    一、DbContext介绍

    DbContext是Entity Framework(EF)操作数据库的上下文网关(接口)。我们对数据库的所有操作都是通过DbContext完成的。下面我们将讨论在code first模式下如何创建自己的DbContext并配置优化。

    二、创建DbContext

    代码如下:


    using System;
    using System;
    using System.Collections.Generic;
    using System.Data.Entity;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using OwinW.Core.Entity;
    using System.Data.Entity.ModelConfiguration.Conventions; namespace OwinW.Core.EFHelper { /// <summary> /// EF访问数据库的接口 /// </summary> public class MyDbContext : System.Data.Entity.DbContext { //在config中配置数据库的名称 private static string dbName = System.Configuration.ConfigurationManager.AppSettings["dbName"]; public MyDbContext() : base(dbName) { //解决团队开发中,多人迁移数据库造成的修改覆盖问题。 Database.SetInitializer<MyDbContext>(null); //base.Configuration.AutoDetectChangesEnabled = false; ////关闭EF6.x 默认自动生成null判断语句 //base.Configuration.UseDatabaseNullSemantics = true; } protected override void OnModelCreating(DbModelBuilder modelBuilder) { //表名不用复数形式 modelBuilder.Conventions.Remove<PluralizingTableNameConvention>(); //移除一对多的级联删除约定,想要级联删除可以在 EntityTypeConfiguration<TEntity>的实现类中进行控制 modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>(); //多对多启用级联删除约定,不想级联删除可以在删除前判断关联的数据进行拦截 modelBuilder.Conventions.Remove<ManyToManyCascadeDeleteConvention>(); base.OnModelCreating(modelBuilder); } //下面放置的是数据库对应的实体对象 //格式如下: public DbSet<Demo> Demo { get; set; } } }

    三、小结

    上面我们就创建了一个自定义的DbContext。并做了一些配置,配置的说明在代码中已经标注了,具体作用我就不再说明了。

  • 相关阅读:
    经验:Library Cache Lock之异常分析-云和恩墨技术通讯精选
    Schnorr 签名算法与聚合签名
    5G 第五代移动通信网络
    《机器学习》周志华西瓜书习题参考答案:第9章
    启动tomcat,在黑色窗口中看到乱码
    Linux系统目录结构以及简单说明
    Linux系统目录结构以及简单说明
    锤子科技官网:问题整理及注意事项
    锤子科技官网:问题整理及注意事项
    锤子科技官网:问题整理及注意事项
  • 原文地址:https://www.cnblogs.com/shiningrise/p/5605502.html
Copyright © 2011-2022 走看看