Entity Framework(EF)Code First,数据库已经存在,然后在代码中更改了表,迁移不了!说已经存在某个表对象。

不懂必须要问 2013-04-03 04:29:59
Entity Framework(EF)Code First,数据库已经存在,然后在代码中更改了表,迁移不了!

是不是code first 一定要在没有数据库的情况下才可以进行迁移?我的数据库已经有了。用code first,现在悲剧啦


PM> Enable-Migrations
正在检查上下文的目标是否为现有数据库...
已为项目 NETGameDatabase 启用 Code First 迁移。
PM> Add-Migration DataBase_Init
正在为迁移“DataBase_Init”搭建基架。
此迁移文件的设计器代码包含当前 Code First 模型的快照。在下一次搭建迁移基架时,将使用此快照计算对模型的更改。如果对要包含在此迁移中的模型进行其他更改,则您可通过再次运行“Add-Migration 201304030827572_DataBase_Init”重新搭建基架。
PM> update-database
指定“-Verbose”标记以查看应用于目标数据库的 SQL 语句。
正在应用基于代码的迁移: [201304030827572_DataBase_Init]。
正在应用基于代码的迁移: 201304030827572_DataBase_Init。
System.Data.SqlClient.SqlException (0x80131904): 数据库中已存在名为 'XGame' 的对象。
在 System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction)
在 System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction)
在 System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj, Boolean callerHasConnectionLock, Boolean asyncClose)
在 System.Data.SqlClient.TdsParser.TryRun(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj, Boolean& dataReady)
在 System.Data.SqlClient.SqlCommand.RunExecuteNonQueryTds(String methodName, Boolean async, Int32 timeout)
在 System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource`1 completion, String methodName, Boolean sendToPipe, Int32 timeout, Boolean asyncWrite)
在 System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
在 System.Data.Entity.Migrations.DbMigrator.ExecuteSql(DbTransaction transaction, MigrationStatement migrationStatement)
在 System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ExecuteSql(DbTransaction transaction, MigrationStatement migrationStatement)
在 System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable`1 migrationStatements)
在 System.Data.Entity.Migrations.Infrastructure.MigratorBase.ExecuteStatements(IEnumerable`1 migrationStatements)
在 System.Data.Entity.Migrations.DbMigrator.ExecuteOperations(String migrationId, XDocument targetModel, IEnumerable`1 operations, Boolean downgrading, Boolean auto)
在 System.Data.Entity.Migrations.DbMigrator.ApplyMigration(DbMigration migration, DbMigration lastMigration)
在 System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ApplyMigration(DbMigration migration, DbMigration lastMigration)
在 System.Data.Entity.Migrations.DbMigrator.Upgrade(IEnumerable`1 pendingMigrations, String targetMigrationId, String lastMigrationId)
在 System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.Upgrade(IEnumerable`1 pendingMigrations, String targetMigrationId, String lastMigrationId)
在 System.Data.Entity.Migrations.DbMigrator.Update(String targetMigration)
在 System.Data.Entity.Migrations.Infrastructure.MigratorBase.Update(String targetMigration)
在 System.Data.Entity.Migrations.Design.ToolingFacade.UpdateRunner.RunCore()
在 System.Data.Entity.Migrations.Design.ToolingFacade.BaseRunner.Run()
ClientConnectionId:be998fcf-3f6c-422a-8a9e-0b2c305c928e
数据库中已存在名为 'XGame' 的对象。

...全文
1946 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
lzzylyj 2015-11-16
  • 打赏
  • 举报
回复
未解析成员“System.Data.Entity.Migrations.Design.ToolingFacade+UpdateRunner,EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”的类型。未解析成员是什么原因
sinat_17111003 2014-07-01
  • 打赏
  • 举报
回复
引用 7 楼 zengding123 的回复:
我的也是,生成的迁移代码都是创建表的,可是我数据库中的表都已经存在了啊。。。
你可以把所有createtable屏蔽掉。再update-database。。之后就没有问题了。。 楼主问题也可以通过这种方式解决。
zengding123 2014-05-23
  • 打赏
  • 举报
回复
我的也是,生成的迁移代码都是创建表的,可是我数据库中的表都已经存在了啊。。。
huwei001982 2013-11-07
  • 打赏
  • 举报
回复
我找到方法了,先把原数据库的 XGame 表改名,再运行 update-database, 然后再把 XGame 改回来
huwei001982 2013-11-06
  • 打赏
  • 举报
回复
楼主还在? 这个问题解决了吗
不懂必须要问 2013-04-03
  • 打赏
  • 举报
回复
没办法解决了吗?
不懂必须要问 2013-04-03
  • 打赏
  • 举报
回复
妈的呀,处处碰头呀,一头雾水
不懂必须要问 2013-04-03
  • 打赏
  • 举报
回复
引用 1 楼 a346729576 的回复:
看来LZ这个问题已经解决了?
一直update-database都是创建表,但我的表已经存在啦。我已经有数据库了。
夜色镇歌 2013-04-03
  • 打赏
  • 举报
回复
看来LZ这个问题已经解决了?

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧