【问题标题】:Error: Invalid object name 'dbo.__MigrationHistory'. with custom schema name错误:无效的对象名称“dbo.__MigrationHistory”。具有自定义架构名称
【发布时间】:2015-11-21 04:29:12
【问题描述】:

尝试从包管理器运行“更新数据库”时出现异常。无论是否使用脚手架迁移,都会发生这种情况。

我有以下几点:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{

    modelBuilder.HasDefaultSchema("final");
    ...
    ...
}

我刚刚创建了这个数据库并进行了几次更新,一切都很顺利。 EF 将 __MigrationsHistory 表放在“最终”模式中,因为它应该具有 (final.__MigrationsHistory)。但在某些时候,我做了一个“更新数据库”并得到了下面的错误。

我想我可以看到 EF 自动生成的 SQL 脚本有什么问题。我认为最后一行(导致异常的行)应该在尝试删除 dbo__MigrationsHistory 之前检查它是否存在。或者,在尝试将其内容移动到自定义架构的迁移历史表之前,首先检查 dbo__MigrationsHistory 是否存在。

出于某种原因,EF 认为我有一个 dbo.__MigrationsHistory 表,而我从未这样做过。

所以,我认为这是 EF 中的一个错误。我正在使用 EF 6.1.3。

也许有人知道这件事。

自动生成的 SQL 迁移脚本到此结束……

...
IF object_id('final.__MigrationHistory') IS NULL BEGIN
        CREATE TABLE [final].[__MigrationHistory] (
            [MigrationId] [nvarchar](150) NOT NULL,
            [ContextKey] [nvarchar](300) NOT NULL,
            [Model] [varbinary](max) NOT NULL,
            [ProductVersion] [nvarchar](32) NOT NULL,
            CONSTRAINT [PK_final.__MigrationHistory] PRIMARY KEY ([MigrationId], [ContextKey])
        )
    END
    INSERT INTO [final].[__MigrationHistory]
    SELECT * FROM [dbo].[__MigrationHistory]
    WHERE [ContextKey] = 'MyNamespace.Migrations.Configuration'
    DELETE [dbo].[__MigrationHistory]
    WHERE [ContextKey] = 'MyNamespace.Migrations.Configuration'
    IF NOT EXISTS(SELECT * FROM [dbo].[__MigrationHistory])
        DROP TABLE [dbo].[__MigrationHistory]
    System.Data.SqlClient.SqlException (0x80131904): Invalid object name 'dbo.__MigrationHistory'.
       at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction)
       at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction)
       at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj, Boolean callerHasConnectionLock, Boolean asyncClose)
       at System.Data.SqlClient.TdsParser.TryRun(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj, Boolean& dataReady)
       at System.Data.SqlClient.SqlCommand.RunExecuteNonQueryTds(String methodName, Boolean async, Int32 timeout, Boolean asyncWrite)
       at System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource`1 completion, String methodName, Boolean sendToPipe, Int32 timeout, Boolean asyncWrite)
       at System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
       at System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher.<NonQuery>b__0(DbCommand t, DbCommandInterceptionContext`1 c)
       at System.Data.Entity.Infrastructure.Interception.InternalDispatcher`1.Dispatch[TTarget,TInterceptionContext,TResult](TTarget target, Func`3 operation, TInterceptionContext interceptionContext, Action`3 executing, Action`3 executed)
       at System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher.NonQuery(DbCommand command, DbCommandInterceptionContext interceptionContext)
       at System.Data.Entity.Internal.InterceptableDbCommand.ExecuteNonQuery()
       at System.Data.Entity.Migrations.DbMigrator.ExecuteSql(MigrationStatement migrationStatement, DbConnection connection, DbTransaction transaction, DbInterceptionContext interceptionContext)
       at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ExecuteSql(MigrationStatement migrationStatement, DbConnection connection, DbTransaction transaction, DbInterceptionContext interceptionContext)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable`1 migrationStatements, DbConnection connection, DbTransaction transaction, DbInterceptionContext interceptionContext)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinTransaction(IEnumerable`1 migrationStatements, DbTransaction transaction, DbInterceptionContext interceptionContext)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinNewTransaction(IEnumerable`1 migrationStatements, DbConnection connection, DbInterceptionContext interceptionContext)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable`1 migrationStatements, DbConnection connection, DbInterceptionContext interceptionContext)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable`1 migrationStatements, DbConnection connection)
       at System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClass30.<ExecuteStatements>b__2e()
       at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.<>c__DisplayClass1.<Execute>b__0()
       at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute[TResult](Func`1 operation)
       at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute(Action operation)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable`1 migrationStatements, DbTransaction existingTransaction)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable`1 migrationStatements)
       at System.Data.Entity.Migrations.Infrastructure.MigratorBase.ExecuteStatements(IEnumerable`1 migrationStatements)
       at System.Data.Entity.Migrations.DbMigrator.ExecuteOperations(String migrationId, VersionedModel targetModel, IEnumerable`1 operations, IEnumerable`1 systemOperations, Boolean downgrading, Boolean auto)
       at System.Data.Entity.Migrations.DbMigrator.ApplyMigration(DbMigration migration, DbMigration lastMigration)
       at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ApplyMigration(DbMigration migration, DbMigration lastMigration)
       at System.Data.Entity.Migrations.DbMigrator.Upgrade(IEnumerable`1 pendingMigrations, String targetMigrationId, String lastMigrationId)
       at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.Upgrade(IEnumerable`1 pendingMigrations, String targetMigrationId, String lastMigrationId)
       at System.Data.Entity.Migrations.DbMigrator.UpdateInternal(String targetMigration)
       at System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClassc.<Update>b__b()
       at System.Data.Entity.Migrations.DbMigrator.EnsureDatabaseExists(Action mustSucceedToKeepDatabase)
       at System.Data.Entity.Migrations.Infrastructure.MigratorBase.EnsureDatabaseExists(Action mustSucceedToKeepDatabase)
       at System.Data.Entity.Migrations.DbMigrator.Update(String targetMigration)
       at System.Data.Entity.Migrations.Infrastructure.MigratorBase.Update(String targetMigration)
       at System.Data.Entity.Migrations.Design.ToolingFacade.UpdateRunner.Run()
       at System.AppDomain.DoCallBack(CrossAppDomainDelegate callBackDelegate)
       at System.AppDomain.DoCallBack(CrossAppDomainDelegate callBackDelegate)
       at System.Data.Entity.Migrations.Design.ToolingFacade.Run(BaseRunner runner)
       at System.Data.Entity.Migrations.Design.ToolingFacade.Update(String targetMigration, Boolean force)
       at System.Data.Entity.Migrations.UpdateDatabaseCommand.<>c__DisplayClass2.<.ctor>b__0()
       at System.Data.Entity.Migrations.MigrationsDomainCommand.Execute(Action command)
    ClientConnectionId:ff9329dc-c707-43bd-b2da-78f4e41ba3d6
    Error Number:208,State:1,Class:16
    Invalid object name 'dbo.__MigrationHistory'.

【问题讨论】:

    标签: entity-framework ef-code-first entity-framework-6 entity-framework-migrations


    【解决方案1】:

    嗯,有一个解决方法。

    如果您使用以下代码将文件添加到您的项目中,一切都会奏效。

    using System.Data.Entity;
    using System.Data.Entity.Migrations.History;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace MyNamespace.Migrations
    {
        public class CustomHistoryContext : HistoryContext
        {
            public CustomHistoryContext(DbConnection dbConnection, string defaultSchema)
                : base(dbConnection, defaultSchema)
            {
            }
    
            protected override void OnModelCreating(DbModelBuilder modelBuilder)
            {
                base.OnModelCreating(modelBuilder);
                modelBuilder.Entity<HistoryRow>().ToTable(tableName: "__MigrationHistory", schemaName: "dbo");
                //modelBuilder.Entity<HistoryRow>().Property(p => p.MigrationId).HasColumnName("Migration_ID");
            }
        }
    
        public class CustomHistoryConfiguration : DbConfiguration
        {
            public CustomHistoryConfiguration()
            {
                this.SetHistoryContext("System.Data.SqlClient",
                    (connection, defaultSchema) => new CustomHistoryContext(connection, defaultSchema));
            }
        }
    }
    

    我从这里得到它: http://blog.oneunicorn.com/2012/02/27/code-first-migrations-making-__migrationhistory-not-a-system-table/

    上面的代码导致 EF 将您的 MigrationsHistory 表/条目放在 dbo 架构中 - 即使您使用其他架构作为默认架构。

    【讨论】:

      猜你喜欢
      • 2016-09-02
      • 1970-01-01
      • 1970-01-01
      • 2015-07-12
      • 2014-01-19
      • 1970-01-01
      • 1970-01-01
      • 2018-12-27
      • 2011-05-20
      相关资源
      最近更新 更多