DropCreateDatabaseAlways与Code First不兼容Azure Sql数据库

时间:2016-10-21 08:09:23

标签: entity-framework azure ef-code-first azure-service-fabric ef-migrations

我正在尝试创建一个微服务架构。我有一个无状态服务与Azure Service Cluster Fabric上部署的Entity Framework相结合。 但是我的问题是当我有一个带DropCreateDatabaseAlways的初始化程序时,数据库被删除但没有重新创建。

我有以下初始化程序:

dinner = ObjectUtils.defaultIfNull(cage.getChicken(),getFreeRangeChicken())

具有以下背景:

class CompanyInitializer : DropCreateDatabaseAlways<CompanyContext>
{
    protected override void Seed(CompanyContext context)
    {
        var companies = new List<Company>
        {
            new Company { Name = "AAA", City = "Eindhoven", Streetname="Street 12" },
            new Company { Name = "BBB", City = "Rotterdam", Streetname = "Street 12" },
            new Company { Name = "CCC", City = "Eindhoven", Streetname = "Street 12" }
        };

        companies.ForEach(s => context.Companies.Add(s));
        context.SaveChanges();

        base.Seed(context);
    }
}

我通过无状态服务的构造函数连接这些:

public class CompanyContext : DbContext
    {
        public CompanyContext(string connectionString) : base(connectionString)
        {
            this.Database.Connection.ConnectionString = connectionString;
            Database.SetInitializer<CompanyContext>(new CompanyInitializer());
        }
        public DbSet<Company> Companies { get; set; }
    }

连接字符串如下:

public StatelessServiceCompany(StatelessServiceContext context)
            : base(context)
        {
            _databaseConnectionstring = WebConfigurationManager.AppSettings["Entity.Framework.ConnectionString"];
            _context = new CompanyContext(_databaseConnectionstring);

            new CompanyInitializer().InitializeDatabase(_context);
        }

问题是数据库被删除但从未重新创建。我相信通过Azure平台上的代码创建数据库缺少权限。

其次,服务群集结构不允许我为项目启用迁移。通过程序包管理器控制台启用迁移时,我收到以下错误:

  

“System.BadImageFormatException:无法加载文件或程序集   'StatelessServiceCompany'或其依赖项之一。一次尝试   用于加载格式不正确的程序。“

我该如何解决这个问题。我不想通过Ado.net复制实体框架。

修改

我通过删除初始化程序并启用迁移来解决我的问题。启用迁移的解决方案位于Properties&gt;下的Platform Target中。建立。在x64和x86之间切换平台目标似乎可以解决问题。配置文件中的种子功能也是一种初始化器。

1 个答案:

答案 0 :(得分:1)

你的问题包括两个问题:

  • 数据库初始化和
  • 架构迁移

我将只讨论第一个,因为这是您最关心的问题。 这两个问题可能是连接在一起的,也可能不是。

初始化程序 DropCreateDatabaseAlways ,毫无疑问,在运行应用程序时会丢弃数据库,但它不会立即重新创建新数据库。相反,它等待特定应用程序域中的第一个上下文使用,然后才重新创建它。

https://msdn.microsoft.com/en-us/library/gg679506(v=vs.113).aspx