jjzjj

Migration

全部标签

ruby-on-rails - ruby rails : adding columns to existing database

我收到一个错误:SQLite3::SQLException:nosuchcolumn:ideas.list_id:SELECT"ideas".*FROM"ideas"WHERE"ideas"."list_id"=2但是我加了t.integer:list_id到我的数据库迁移文件:classCreateIdeas这给了我这个:classCreateIdeas然后我输入rakedb:migrate知道为什么我会收到一条错误消息说没有专栏吗?我对RoR还是陌生的。我必须以其他方式添加一列吗?谢谢 最佳答案 正如Speransky所建议的,

ruby-on-rails - Rails 5 的 ActiveRecord::Migration 中的 [5.0] 是什么意思?

我在Rails5应用程序中创建的迁移将5.0传递到一个方法中:classCreateVariableKeys我想知道[5.0]是什么意思。 最佳答案 它是ActiveRecord::Migration的类方法,定义为here.它允许我们在4.2和5.0之间选择我们希望使用的迁移版本。该方法抛出一个:"Unknownmigrationversion..."如果将不兼容的版本作为参数传递,则会出错。ActiveRecord的生产就绪版本没有该方法,因此它应该在Rails5结束测试版后立即消失。

ruby-on-rails - rails : How to delete a pending migration

我目前正在学习ruby​​onrails教程:http://guides.rubyonrails.org/getting_started.html.我正在尝试将数据保存到数据库中。但是,当我运行:railsserver时,出现以下错误:Migrationsarepending.Toresolvethisissue,run:bin/rakedb:migrateRAILS_ENV=development我看过其他文章,当我运行时:bin/rakedb:migrate我得到一个rakeaborted!运行后:rakedb:abort_if_pending_migrations....我看到了

ruby-on-rails - 运行 rake db :migrate 时,Rails 创建迁移以将列添加到表中会导致错误

我创建了一个名为“用户”的模型,我创建了一个新的迁移以将一些列添加到用户表中。现在,当我运行rakedb:migrate时,我得到以下b/c错误,它正在尝试再次创建用户表$rakedb:migrate==DeviseCreateUsers:migrating==============================================--create_table(:users)rakeaborted!Anerrorhasoccurred,alllatermigrationscanceled:Mysql::Error:Table'users'alreadyexists:CR

ruby-on-rails - 清除旧的 Rails 迁移文件是个好主意吗?

我已经运行一个大型Rails应用程序2年多了,一天天过去,我的ActiveRecord迁移文件夹已经增长到超过150个文件。有一些非常旧的模型,在应用程序中不再可用,但仍会在迁移中引用。我想删除它们。你怎么看?您通常会从代码库中清除旧的迁移吗? 最佳答案 TheRails4Way第177页:塞巴斯蒂安说……Alittle-knownfactisthatyoucanremoveoldmigrationfiles(whilestillkeepingnewerones)tokeepthedb/migratefoldertoamanagea

ruby - Ruby 模型的数组属性

是否可以为数组类创建属性?我试着阅读this但我并没有从中得到太多。我想做这样的事情:classCreateArches这样当我在Arch实例上调用.thearray时,我得到一个数组,我可以向其中添加新元素。ruby-1.9.2-p290:006>arc=Arch.newruby-1.9.2-p290:007>arc.thearray=>[] 最佳答案 创建一个带有文本字段的模型>railsgmodelArchesthearray:textinvokeactive_recordcreatedb/migrate/2011111117

ruby-on-rails - 如何(替换|创建)rails 2.0 迁移中的枚举字段?

我想在我正在进行的迁移中创建一个枚举字段,我尝试在谷歌中搜索但我找不到在迁移中执行此操作的方法我唯一找到的是t.column:status,:enum,:limit=>[:accepted,:cancelled,:pending]但看起来上面的代码只在rails1.xxx上运行,因为我正在运行rails2.0这是我尝试过的但是失败了classCreatePayments[:accepted,:cancelled,:pending]t.timestampsendenddefself.downdrop_table:paymentsendend那么,如果不允许这样做,您认为什么是好的解决方案

ruby-on-rails - 从 schema.rb 生成迁移文件

我希望从schema.rb生成一个迁移文件。是否可以?目前我有很多迁移文件,想将所有内容合并到一个主迁移文件中。我还认为我可能在某个时候不小心删除了一个迁移文件。谢谢你的帮助 最佳答案 您可以将schema.rb复制并粘贴到迁移中并回溯它(例如更改日期),这样现有的数据库就不会运行它。创建此迁移后,您可以删除所有旧迁移。我不同意Andrew不应该删除迁移的观点。迁移总是基于模型类的变化而意外中断,修复它们非常重要。由于我确定您正在使用版本控制,因此如果您需要它们以供引用,您可以随时回顾历史。

ruby-on-rails - Rails Migrations 可以用来转换数据吗?

我正在尝试转换我的Rails应用程序中的列,为了论证,让我们假设我正在尝试将我的users表中的age列更改为字符串表示形式而不是int。在我的迁移中我有这个;def.selfupadd_column:users,:age_text,:stringusers=User.find(:all)users.eachdo|u|u.age_text=convert_to_text(u.age)u.saveendenddefself.convert_to_text(number)#codeheretoconvert1to'one'etcend但它似乎没有用,我在这里尝试的是否可以通过迁移实现?

ruby-on-rails - Rails 4 迁移 : how to reorder columns

我了解到add_column有一个:after选项来设置插入列的位置。太糟糕了,我才知道它:在添加了一堆之后。如何编写迁移以简单地对列进行重新排序? 最佳答案 当使用MySQL时,您可以调用change_column,但是您必须重复列类型(只需从您的其他迁移中复制并粘贴它):defupchange_column:your_table,:some_column,:integer,after::other_columnend或者如果您必须对一个表中的多个列重新排序:defupchange_table:your_tabledo|t|t.c