资讯专栏INFORMATION COLUMN

Entity Framework 小知识(二)

joy968 / 1691人阅读

摘要:零基于代码配置基于代码配置是新增的一个特性,操作步骤如下创建派生类配置默认连接工厂设置设置数据库初始化器创建派生类接下来使用属性在上下文类中设置基于代码的配置类配置默认连接工厂使用方法设置默认连接工厂以数据库为例设置使用方法配置数据库提供程

零、基于代码配置

基于代码配置是EF6新增的一个特性,操作步骤如下:

创建DbConfig派生类;

配置默认连接工厂;

设置Database Provider

设置数据库初始化器;

1. 创建DbConfig派生类
public class EF6Config:DbConfiguration
{
    public EF6Config(){}
}

接下来使用 DbConfigurationType 属性在上下文类中设置基于代码的配置类:

[DbConfigurationType(typeof(EF6Config))]
public partial class EF6DbContext:DbContext
{
  public EF6DbContext():base("name=EF6DbContext"){}  
}
2. 配置默认连接工厂

使用 SetDefaultConnectionFactory 方法设置默认连接工厂(以SQL SERVER 数据库为例):

public class EF6Config:DbConfiguration
{
    public EF6Config()
    {
      this.SetDefaultConnectionFactory(new System.Data.Entity,Infrastructure.SqlConnectionFactory());
    }
}
3. 设置Database Provider

使用 SetProviderServices() 方法配置数据库提供程序:

public class EF6Config:DbConfiguration
{
    public EF6Config()
    {
      this.SetDefaultConnectionFactory(new System.Data.Entity,Infrastructure.SqlConnectionFactory());

      this.SetProviderServices("System.Data.SqlClient",System.Data.Entity.SqlServer.SqlProviderServices.Instance);
    }
}
4. 设置数据库初始化器

在使用 code first 的情况下,可以使用基于代码的配置数据库的初始值:

public class EF6Config:DbConfiguration
{
    public EF6Config()
    {
      this.SetDefaultConnectionFactory(new System.Data.Entity,Infrastructure.SqlConnectionFactory());

      this.SetProviderServices("System.Data.SqlClient",System.Data.Entity.SqlServer.SqlProviderServices.Instance);

      this.SetDatabaseInitializer(new CustomDBInitializer(EF6DbContext)());
    }
}
注:.config 中  的配置优于代码配置,也就是说,如果同时在 .config 中和代码中都设置了配置选项,则优先使用 .config 中的设置。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/61502.html

相关文章

  • Entity Framework 知识

    摘要:零基于代码配置基于代码配置是新增的一个特性,操作步骤如下创建派生类配置默认连接工厂设置设置数据库初始化器创建派生类接下来使用属性在上下文类中设置基于代码的配置类配置默认连接工厂使用方法设置默认连接工厂以数据库为例设置使用方法配置数据库提供程 零、基于代码配置 基于代码配置是EF6新增的一个特性,操作步骤如下: 创建DbConfig派生类; 配置默认连接工厂; 设置Database P...

    sunny5541 评论0 收藏0
  • Entity Framework 知识(三)

    摘要:中解决并发有两种方式利用并发利用行版本的方式代码如下利用并发利用行版本注在并发量不是很大的时候可以使用的乐观并发,在访问量很大的时候应该使用其他技术处理并发问题。 零、乐观并发 在单服务器上运行的站点,为了防止出现脏读现象,我们一般使用Lock语句关键字,但是如果在分布式站点上使用Lock语句关键字是不起作用的,因为程序锁住了服务器1数据库实例,但服务器2并不知道服务器1已被锁住,这样...

    alogy 评论0 收藏0
  • Entity Framework 知识(三)

    摘要:中解决并发有两种方式利用并发利用行版本的方式代码如下利用并发利用行版本注在并发量不是很大的时候可以使用的乐观并发,在访问量很大的时候应该使用其他技术处理并发问题。 零、乐观并发 在单服务器上运行的站点,为了防止出现脏读现象,我们一般使用Lock语句关键字,但是如果在分布式站点上使用Lock语句关键字是不起作用的,因为程序锁住了服务器1数据库实例,但服务器2并不知道服务器1已被锁住,这样...

    2shou 评论0 收藏0
  • Entity Framework 知识(五)

    摘要:在多对多关系映射中关联表是自动生成的。但有时候我们需要显示定义关联表。 在 多对多关系映射 中关联表是EF自动生成的。但有时候我们需要显示定义关联表。我们可以按照如下步骤定义(继续使用多对多关系映射这篇文章饿代码): 定义关联表类: public class StudentCourses : BaseEntity { public int StudentId { get; se...

    aboutU 评论0 收藏0
  • Entity Framework 知识(四)

    摘要:在中并没有提供包含索引和过滤索引的创建方法,那么我们就么发创建了吗答案是否定的,我们可以通过迁移类进行创建包含索引和过滤索引。首先我们通过命令创建一个空的迁移类,然后在方法中输入如下代码在方法中输入如下代码 在EF中并没有提供包含索引和过滤索引的创建方法,那么我们就么发创建了吗?答案是否定的,我们可以通过迁移类进行创建包含索引和过滤索引。首先我们通过 Add-Migration 命令创...

    jackzou 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<