Este artigo é um artigo espelhado de tradução automática, por favor clique aqui para ir para o artigo original.

Vista: 27080|Resposta: 0

[Fonte] Atualize seu banco de dados com a migração Code First

[Copiar link]
Publicado em 07/06/2018 15:56:58 | | |
Migração Code First, você pode atualizar suas alterações no modelo do seu código para o banco de dados; para usar a migração Code First, primeiro precisa abri-lo:

No console Tools-NuGet Package Manager-Package Manager, tipo: Enable-Migrations -ContextTypeName CodeFirstExistingDB.DataModel.StoreContext, pressione Enter. (Note que você precisa definir o contexto que precisa usar porque o contexto de autenticação é criado automaticamente quando você cria o projeto.) Uma vez feito, uma pasta Migrações é criada, que contém uma classe Configuration.cs.

Neste ponto, há uma etapa extra necessária para fazer o Code First funcionar; se você criar uma migração agora, ele tentará adicionar a entidade contextual ao banco de dados, e a migração falhará porque as tabelas de Produtos e categorias já existem no banco de dados. Primeiro, precisamos criar uma migração inicializada para vazio, e então podemos adicionar uma migração a quaisquer modificações.

PM> Atualização - Banco de Dados
Especifique a flag "-Verbose" para visualizar as instruções SQL aplicadas ao banco de dados alvo.
Sem migrações explícitas pendentes.
Aplicando migração automática: 201806070740457_AutomaticMigration.
System.Data.SqlClient.SqlException (0x80131904): Um objeto chamado 'Account' já existe no banco de dados.
   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)
   Em 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)
   Em System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource'1 completion, String methodName, Boolean sendToPipe, Int32 timeout, Boolean& usedCache, Boolean asyncWrite, Boolean inRetry)
   Em System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
   Em System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher. <NonQuery>b__0(DbCommand t, DbCommandInterceptionContext'1 c)
   Em System.Data.Entity.Infrastructure.Interception.InternalDispatcher'1.Dispatch[TTarget,TInterceptionContext,TResult](TTarget alvo, operação Func'3, TInterceptionContext interceptionContext, Ação'3 executando, Ação'3 executada)
   Em System.Data.Entity.Infrastructure.Interception.DbCommandDispatcher.NonQuery(Comando DbCommand, DbCommandInterceptionContexto interceptionContext)
   Em System.Data.Entity.Internal.InterceptableDbCommand.ExecuteNonQuery()
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteSQL (MigrationStatement migrationStatement, conexão DbConnection, transação DbTransaction, DbInterceptionContext interceptaçãoContexto)
   Em System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ExecuteSql(MigrationStatement migrationStatement, conexão DbConnection, transação DbTransaction , DbInterceptionContexto interceptaçãoContexto)
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, conexão DbConnection, transação DbTransaction, DbInterceptionContexto interceptaçãoContexto)
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinTransaction(IEnumerable'1 migrationStatements, DbTransaction transaction, DbInterceptionContext interceptaçãoContexto)
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsWithinNewTransaction(IEnumerable'1 migrationStatements, conexão DbConnection, DbInterceptionContext interceptaçãoContexto)
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, conexão DbConnection, DbInterceptionContexto interceptionContexto)
   em System.Data.Entity.Migrations.DbMigrator.ExecuteStatementsInternal(IEnumerable'1 migrationStatements, conexão DbConnection)
   em System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClass32. <ExecuteStatements>b__30()
   Em System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.<>c__DisplayClass1. <Execute>b__0()
   at System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute[TResult](Func'1 operation)
   Em System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy.Execute(Action operation)
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable'1 migrationStatements, DbTransaction existentingTransaction)
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable'1 migrationStatements)
   em System.Data.Entidade.Migrações.Infraestrutura.MigratorBase.ExecuteStatements(IEnumerable'1 migrationStatements)
   Em System.Data.Entity.Migrations.DbMigrator.ExecuteOperations(String migrationId, VersionedModel targetModel, IEnumerable'1 operations, IEnumerable'1 systemOperations, Boolean rebaixando, auto booleano)
   em System.Data.Entity.Migrations.DbMigrator.AutoMigrate(String migrationId, VersionedModel sourceModel, VersionedModel targetModel, downgrade booleano)
   Em System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.AutoMigrate(String migrationId, VersionedModel sourceModel, VersionedModel targetModel, Boolean rebaixando)
   at System.Data.Entity.Migrations.DbMigrator.Upgrade(IEnumerable'1 pendentingMigrations, StringTargetMigrationId, String lastMigrationId)
   em System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.Upgrade(IEnumerable'1 pendentingMigrations, StringTargetMigrationId, String lastMigrationId)
   em System.Data.Entity.Migrations.DbMigrator.UpdateInternal(String targetMigration)
   Em System.Data.Entity.Migrations.DbMigrator.<>c__DisplayClasse. <Update>b__d()
   em System.Data.Entity.Migrations.DbMigrator.EnsureDatabaseExists(Ação deveSucedeRDeixarBancoDados)
   em System.Data.Entity.Migrations.Infrastructure.MigratorBase.EnsureDatabaseExists(Ação deveSucederParaDeixarBanco)
   em System.Data.Entity.Migrations.DbMigrator.Update(String targetMigration)
   Em System.Data.Entity.Migrations.Infrastructure.MigratorBase.Update(String targetMigration)
   em System.Data.Entity.Migrations.Design.ToolingFacade.UpdateRunner.RunCore()
   Em System.Data.Entity.Migrations.Design.ToolingFacade.BaseRunner.Run()
ClientConnectionId:dcf676a8-d2b3-4232-89dd-35e15fb8160d
Erro Número: 2714, Estado: 6, Classe: 16
Um objeto chamado 'Account' já existe no banco de dados.

Se você encontrar o erro acima, digite Add-Migration Initial Create -IgnoreChanges no console do Gerenciador de Pacotes para criar uma migração vazia.

O logo IgnoreChanges é usado para garantir que nada seja feito nessa migração. Fazer isso cria uma tabela de migrações no banco de dados, que é um snapshot do banco antes de ser migrado.

Em seguida, insira update-database no console do gerenciador de pacotes para atualizar a migração de inicialização para o banco de dados.

Após a inicialização da migração, atualize o banco de dados usando a Migração Code First:

Adicione a coluna Descrip{filter}tion à tabela Product e defina o comprimento para 50, ([StringLength(50)]); Agora adicione uma nova migração para atualizar as mudanças no banco de dados.

No console do Gerenciador de Pacotes, insira a:Add-Migration add_product_descrip{filter}tion, (add_product_descrip{filter}tion) adicionará um arquivo à pasta Migrações para descrever a migração. Em seguida, no console do Gerenciador de Pacotes, digite:

Atualização-banco de dados, a nova coluna será adicionada à tabela Produtos.





Anterior:Demonstração de conexão de comunicação de porta TCP
Próximo:asp.net mvc usa a visualização local RenderAction para carregar dados dinâmicos
Disclaimer:
Todo software, material de programação ou artigos publicados pela Code Farmer Network são apenas para fins de aprendizado e pesquisa; O conteúdo acima não deve ser usado para fins comerciais ou ilegais, caso contrário, os usuários terão todas as consequências. As informações deste site vêm da Internet, e disputas de direitos autorais não têm nada a ver com este site. Você deve deletar completamente o conteúdo acima do seu computador em até 24 horas após o download. Se você gosta do programa, por favor, apoie um software genuíno, compre o registro e obtenha serviços genuínos melhores. Se houver qualquer infração, por favor, entre em contato conosco por e-mail.

Mail To:help@itsvse.com