Code First 마이그레이션을 사용하면, 코드 내 모델 변경 사항을 데이터베이스에 업데이트할 수 있습니다. Code First 마이그레이션을 사용하려면 먼저 열어야 합니다:
Tools-NuGet 패키지 관리자-패키지 관리자 콘솔에서 type: Enable-Migrations -ContextTypeName CodeFirstExistingDB.DataModel.StoreContext에서 Enter 버튼을 눌러. (프로젝트 생성 시 인증 컨텍스트가 자동으로 생성되므로 사용할 컨텍스트를 정의해야 한다는 점에 유의하세요.) 완료되면 Configuration.cs 클래스를 포함하는 마이그레이션 폴더가 생성됩니다.
이 시점에서 Code First를 작동시키기 위해 추가 단계가 필요합니다. 지금 마이그레이션을 생성하면 컨텍스트 엔티티를 데이터베이스에 추가하려고 시도하지만, 제품과 카테고리 테이블이 이미 데이터베이스에 존재하기 때문에 마이그레이션이 실패합니다. 먼저 빈 상태로 초기화된 마이그레이션을 생성하고, 그 다음 수정 항목에 마이그레이션을 추가할 수 있습니다.
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 completion, 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 작업, TInterceptionContext interceptionContext, Action'3 실행 중, Action'3 실행 중) System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher.NonQuery(DbCommand 명령어, DbCommandInterceptionContext 인터셉션Context) 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) , DbInterceptionContext 인터셉션Context) System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, DbConnection connection, DbTransaction transaction, DbInterceptionContext 인터셉션Context) 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) 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 마이그레이션을 사용하여 데이터베이스를 업데이트합니다:
Descrip{filter}tion 열을 Product 테이블에 추가하고 길이를 50으로 설정하세요, ([StringLength(50)]); 이제 데이터베이스에 변경 사항을 업데이트하기 위해 새로운 마이그레이션을 추가하세요.
패키지 관리자 콘솔에서 다음을 입력하세요:Add-Migration add_product_descrip{filter}tion, (add_product_descrip{filter}tion)는 마이그레이션 폴더에 마이그레이션을 설명하는 파일을 추가합니다. 다음, 패키지 관리자 콘솔에서 다음을 입력하세요:
업데이트-데이터베이스, 새 열은 제품 테이블에 추가됩니다.
|