10

Après la mise à jour de mon Entity Framework vers la version 6.0.0-alpha1, je ne peux pas mettre à jour la base de données. Ce est l'erreur que je reçois:Impossible de mettre à jour la base de données à l'aide des migrations EF après la mise à jour vers EF 6.0.0-alpha

PM> update-database -verbose 
Using StartUp project 'DataCenter'. 
Using NuGet project 'DataCenter.Domain'. 
Specify the '-Verbose' flag to view the SQL statements being applied to the target database. 
Target database is: 'datacenter' (DataSource: ., Provider: System.Data.SqlClient, Origin: Configuration). 
Upgrading history table. 
ALTER TABLE [dbo].[__MigrationHistory] ADD [ContextKey] [nvarchar](512) NOT NULL DEFAULT 'DataCenter.Domain.Migrations.Configuration' 
ALTER TABLE [dbo].[__MigrationHistory] DROP CONSTRAINT [PK_dbo.__MigrationHistory] 
System.Data.SqlClient.SqlException (0x80131904): 'PK_dbo.__MigrationHistory' is not a constraint. 
Could not drop constraint. See previous errors. 
    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) 
    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.Migrations.DbMigrator.ExecuteSql(DbTransaction transaction, MigrationStatement migrationStatement) 
    at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ExecuteSql(DbTransaction transaction, MigrationStatement migrationStatement) 
    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.UpgradeHistory(IEnumerable`1 upgradeOperations) 
    at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.UpgradeHistory(IEnumerable`1 upgradeOperations) 
    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.RunCore() 
    at System.Data.Entity.Migrations.Design.ToolingFacade.BaseRunner.Run() 
ClientConnectionId:eda1a366-d3c8-44de-8cc9-8f64e2511b4e 
'PK_dbo.__MigrationHistory' is not a constraint. 
Could not drop constraint. See previous errors. 

Quelle est la cause de cela? J'ai interrogé la table sysobjects pour 'PK_dbo .__ MigrationHistory' mais cela n'existe pas. une idée?

Merci d'avance.

Répondre

11

OK. J'ai trouvé la solution. Il semble que EF s'attend à ce que la contrainte Clé primaire de la table __MigrationHistory porte le nom PK_dbo.__MigrationHistory. mais c'est PK___MigrationHistory. Par conséquent, les instructions sql suivantes feront l'affaire.

ALTER TABLE __MigrationHistory 
drop CONSTRAINT PK___MigrationHistory 
ALTER TABLE __MigrationHistory 
ADD CONSTRAINT [PK_dbo.__MigrationHistory] PRIMARY KEY (MigrationId) 

après cela, j'ai utilisé la base de données de mise à jour sans erreurs.

+0

merci l'homme a sauvé ma journée – HassanBakri

+0

Vous aurez un problème à l'avenir avec vos prochaines migrations. Le PK devrait être en cluster contenant '[MigrationId]' et '[ContextKey]'. La contrainte PK doit ressembler à ceci: 'CONSTRAINT [PK_dbo .__ MigrationHistory] PRIMARY KEY CLUSTERED ([MigrationId] ASC, [ContextKey] ASC)' – skyfrog

Questions connexes