Ez a cikk egy tükör gépi fordítás, kérjük, kattintson ide, hogy ugorjon az eredeti cikkre.

Nézet: 27080|Válasz: 0

[Forrás] Frissítsd az adatbázisodat Code First migrációval

[Linket másol]
Közzétéve 2018. 06. 07. 15:56:58 | | |
Code First Migration esetén frissítheted a kódod modelljének változásait az adatbázisba, a Code First Migration használatához először meg kell nyitnod:

A Tools-NuGet Package Manager-Package Manager konzolban írd be: Enable-Migrations -ContextTypeName CodeFirstExistingDB.DataModel.StoreContext nyomd meg az Enter gombot. (Fontos megjegyezni, hogy meg kell határoznod a használt kontextust, mert a hitelesítési kontextus automatikusan létrejön a projekt létrehozásakor.) Miután elkészült, létrehoznak egy Migrációk mappát, amely egy Configuration.cs osztályt tartalmaz.

Ezen a ponton egy plusz lépés szükséges ahhoz, hogy a Code First működjön: ha most létrehozol migrációt, megpróbálja hozzáadni a kontextuális entitást az adatbázisba, de a migráció kudarcot vall, mert a Termékek és kategória táblák már léteznek az adatbázisban. Először egy migrációt kell létrehoznunk, amelyet üresre inicializálnak, majd hozzáadhatunk migrációt bármilyen módosításhoz.

PM> Frissítés-adatbázis
Megadjuk a "-Verbose" zászlót, hogy megtekinthesd a cél adatbázisra alkalmazott SQL utasításokat.
Nincsenek függőben lévő explicit migrációk.
Automatikus migráció alkalmazása: 201806070740457_AutomaticMigration.
System.Data.SqlClient.SqlException (0x80131904): Egy 'Account' nevű objektum már létezik az adatbázisban.
   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, Boolean inRetry)
   In System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
   A System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher fájlban. <NonQuery>b__0(DbCommand t, DbCommandInterceptionContext'1 c)
   In System.Data.Entity.Infrastructure.Interception.InternalDispatcher'1.Dispatch[TTarget,TInterceptionContext,TResult](TTarget target, Func'3 operation, TInterceptionContext interceptionContext, Action'3 végrehajtás, Action'3 végrehajtva)
   A System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher.NonQuery (DbCommand parancs, DbCommandInterceptionContext interceptionContext)
   A System.Data.Entity.Internal.InterceptableDbCommand.ExecuteNonQuery() fájlban
   A System.Data.Entity.Migrations.DbMigrator.ExecuteSql(MigrationStatement migrationStatement, DbConnection connection, DbTransaction transaction, DbInterceptionContext interceptionContext)
   A System.Data.Entity.Migrations.Infrastructure.Migrator fájlbanLoggingDecorator.ExecuteSql (MigrationStatement migrationStatement, DbConnection connection, DbTransaction transaction , DbInterceptionContext interceptionContext)
   A System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, DbConnection connection, DbTransaction transaction) területén, DbInterceptionContext interceptionContext)
   A System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinTransaction(IEnumerable'1 migrationStatements, DbTransaction transaction, DbInterceptionContext interceptionContext)
   A System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinNewTransaction(IEnumerable'1 migrationStatements, DbConnection connection, DbInterceptionContext interceptionContext)
   A System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, DbConnection connection, DbInterceptionContext interceptionContext)
   a System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, DbConnection connection) címen
   at System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClass32. <ExecuteStatements>b__30()
   A System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.<>c__DisplayClass1 fájlban. <Execute>b__0()
   at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute[TResult](Func'1 operation)
   System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute(Action operation) fájlban
   A System.Data.Entity.Migrations.DbMigrator.ExecuteStatements (IEnumerable'1 migrationStatements, DbTransaction existingTransaction) területén
   A System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable'1 migrationStatements) fájlban
   a System.Data.Entity.Migrations.Infrastructure.MigratorBase.ExecuteStatements(IEnumerable'1 migrationStatements) címen
   In System.Data.Entity.Migrations.DbMigrator.ExecuteOperations(String migrationId, VersionedModel targetModel, IEnumerable'1 operations, IEnumerable'1 systemOperations, Boolean visszaminősítés, Boolean auto)
   at System.Data.Entity.Migrations.DbMigrator.AutoMigrate(String migrationId, VersionedModel sourceModel, VersionedModel targetModel, Boolean downgrading)
   In System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.AutoMigrate(String migrationId, VersionedModel sourceModel, VersionedModel targetModel, Boolean visszaminősítés)
   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)
   A System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClasse fájlban. <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)
   A System.Data.Entity.Migrations.Infrastructure.MigratorBase.Update (String targetMigration) fájlban
   at System.Data.Entity.Migrations.Design.ToolingFacade.UpdateRunner.RunCore()
   In System.Data.Entity.Migrations.Design.ToolingFacade.BaseRunner.Run()
ClientConnectionId:dcf676a8-d2b3-4232-89dd-35e15fb8160d
Hibaszám:2714,Állam:6,Osztály:16
Az adatbázisban már létezik egy 'Account' nevű objektum.

Ha a fenti hibával találkozol, írd be az Add-Migration InitialCreate -IgnoreChanges menüpontot a Package Manager konzolban, hogy üres migrációt hozz létre.

Az IgnoreChanges logót használják annak érdekében, hogy semmi sem történjen a migráció érdekében. Ezzel létrehoz egy migrációs táblát az adatbázisban, ami az adatbázis pillanatképe a migráció előtt.

Ezután írja be a update-database opciót a csomagkezelő konzolban, hogy frissítse az inicializációs migrációt az adatbázisba.

A migráció inicializálása után frissítse az adatbázist Code First Migration segítségével:

Hozzáadjuk a Descrip{filter}tion oszlopot a Termék táblához, és állítsuk be a hosszt 50-re, ([StringLength(50)]); Most adj hozzá egy új migrációt, hogy frissítsd az adatbázis módosításait.

A Package Manager konzolon írd be:Add-migration add_product_descrip{filter}tion, (add_product_descrip{filter}tion) hozzáad egy fájlt a Migrációk mappába, hogy leírja a migrációt. Ezután a Package Manager konzolban írd be:

update-database, az új oszlopot hozzáadják a Termékek táblához.





Előző:TCP port kommunikációs kapcsolat bemutató
Következő:asp.net mvc a RenderAction helyi nézetet használja a dinamikus adatok betöltésére
Lemondás:
A Code Farmer Network által közzétett összes szoftver, programozási anyag vagy cikk kizárólag tanulási és kutatási célokra szolgál; A fenti tartalmat nem szabad kereskedelmi vagy illegális célokra használni, különben a felhasználók viselik az összes következményet. Az oldalon található információk az internetről származnak, és a szerzői jogi vitáknak semmi köze ehhez az oldalhoz. A fenti tartalmat a letöltés után 24 órán belül teljesen törölni kell a számítógépéről. Ha tetszik a program, kérjük, támogassa a valódi szoftvert, vásároljon regisztrációt, és szerezzen jobb hiteles szolgáltatásokat. Ha bármilyen jogsértés történik, kérjük, vegye fel velünk a kapcsolatot e-mailben.

Mail To:help@itsvse.com