Code First Migrationでは、コード内のモデル変更をデータベースに更新できます。Code First Migrationを使うには、まず開く必要があります:
Tools-NuGet Package Manager-Package Manager コンソールで、type: Enable-Migrations -ContextTypeName CodeFirstExistingDB.DataModel.StoreContext を押し、Enterキーを押してください。 (認証コンテキストはプロジェクト作成時に自動的に作成されるため、使用するコンテキストを定義する必要があります。) 完了後、Configuration.csクラスを含むMigrationsフォルダが作成されます。
この時点でCode Firstを動作させるためには追加のステップが必要で、今移行を作成するとコンテキストエンティティをデータベースに追加しようとしますが、Productsとカテゴリのテーブルがすでにデータベースに存在するため移行は失敗します。 まず、空に初期化された移行を作成し、その後、任意の修正に移行を追加する必要があります。
PM> アップデート・データベース ターゲットデータベースに適用されたSQL文を表示するには「-Verbose」フラグを指定します。 明確な移行が控えているわけではありません。 自動移行の適用:201806070740457_AutomaticMigration。 System.Data.SqlClient.SqlException(0x80131904):データベース内にすでに「Account」という名前のオブジェクトが存在します。 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) In 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) In System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource'1 complete, String methodName, Boolean sendToPipe, Int32 timeout, Boolean& usedCache, Boolean asyncWrite、ブール値を inRetry) In System.Data.SqlClient.SqlCommand.ExecuteNonQuery() System.Data.Entity.Infrastructure.Interception.DbCommandDispatcherにて。 <NonQuery>b__0(DbCommand t, DbCommandInterceptionContext'1 c) System.Data.Entity.Infrastructure.Interception.InternalDispatcher'1.Dispatch[TTarget,TInterceptionContext,TResult](TTarget target, Func'3 operation, Ti nterceptionContext interceptionContext、Action'3実行中、Action'3実行完了) System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher.NonQuery(DbCommandコマンド、DbCommandInterceptionContext interceptionContext) In System.Data.Entity.Internal.InterceptableDbCommand.ExecuteNonQuery() In System.Data.Entity.Migrations.DbMigrator.ExecuteSql(MigrationStatement migrationStatement, DbConnection connection, DbTransaction transaction, DbInterceptionContext インターセプトコンテキスト) System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ExecuteSql(MigrationStatement migrationStatement, DbConnection connection, DbTransaction transaction transaction、DbInterceptionContext interceptionContext) System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, DbConnection connection, DbTransaction transaction, DbInterceptionContext interceptionContext) In System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinTransaction(IEnumerable'1 migrationStatements, DbTransaction transaction, DbInterceptionContext インターセプトコンテキスト) In System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinNewTransaction(IEnumerable'1 migrationStatements, DbConnection connection, DbInterceptionContext インターセプトコンテキスト) 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) System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClass32. <ExecuteStatements>b__30() In System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.<>c__DisplayClass1. <Execute>b__0() at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute[TResult](Func'1 operation) System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute(Action operation) System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable'1 migrationStatements, DbTransaction existingTransaction) System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable'1 migrationStatements) at System.Data.Entity.Migrations.Infrastructure.MigratorBase.ExecuteStatements(IEnumerable'1 migrationStatements) In System.Data.Entity.Migrations.DbMigrator.ExecuteOperations(String migrationId, VersionedModel targetModel, IEnumerable'1 operations, IEnumerable'1 systemOperations, Boolean ダウングレード、ブール自動) at System.Data.Entity.Migrations.DbMigrator.AutoMigrate(String migrationId, VersionedModel sourceModel, VersionedModel targetModel, Boolean downgradeing) In System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.AutoMigrate(String migrationId, VersionedModel sourceModel, VersionedModel targetModel, Boolean ダウングレード) 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) In System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClasse. <Update>b__d() 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) In System.Data.Entity.Migrations.Infrastructure.MigratorBase.Update(String targetMigration) at System.Data.Entity.Migrations.Design.ToolingFacade.UpdateRunner.RunCore() In System.Data.Entity.Migrations.Design.ToolingFacade.BaseRunner.Run()
ClientConnectionId:dcf676a8-d2b3-4232-89dd-35e15fb8160d エラー番号:2714、州:6、クラス:16 「Account」という名前のオブジェクトはすでにデータベースに存在しています。
上記のエラーが発生した場合は、パッケージマネージャーコンソールで「Add-Migration InitialCreate -IgnoreChanges」と入力して空の移行を作成します。
IgnoreChangesのロゴは、この移行に対して何も対策が取られないようにするために使われています。 これを行うと、データベース内にマイグレーションテーブルが作成され、これは移行前のデータベースのスナップショットとなります。
次に、パッケージマネージャーコンソールでupdate-databaseを入力し、データベースへの初期化移行を更新します。
移行が初期化された後、Code First Migrationを使ってデータベースを更新します:
Descrip{filter}tion列をProductテーブルに追加し、長さを50に設定します。([StringLength(50)]); 次に、データベースの変更を更新するために新しい移行を追加してください。
パッケージマネージャーコンソールで、以下を入力してください:Add-Migration add_product_descrip{filter}tion(add_product_descrip{filter}tion)は、移行を記述するファイルを追加してMigrationsフォルダに追加します。 次に、パッケージマネージャーコンソールで以下を入力してください:
更新データベース新しい列はProductsテーブルに追加されます。
|