我们有script/generate migration add_fieldname_to_tablename fieldname:datatype语法,用于向模型添加新列。
在同一行中,是否有用于更改列的数据类型的脚本/generate ?或者我应该直接将SQL写入我的常规迁移中?
我想将一列从datetime改为date。
我们有script/generate migration add_fieldname_to_tablename fieldname:datatype语法,用于向模型添加新列。
在同一行中,是否有用于更改列的数据类型的脚本/generate ?或者我应该直接将SQL写入我的常规迁移中?
我想将一列从datetime改为date。
当前回答
你可以使用change_column:
def change
change_column :table_name, :column_name, :new_data_type
end
其他回答
只需生成迁移:
rails g migration change_column_to_new_from_table_name
像这样更新迁移:
class ClassName < ActiveRecord::Migration
change_table :table_name do |table|
table.change :column_name, :data_type
end
end
最后
rake db:migrate
我不知道您是否可以从命令行创建一个迁移来完成所有这些,但是您可以创建一个新的迁移,然后编辑迁移以执行这个taks。
如果tablename是表的名称,fieldname是字段的名称,并且您希望从一个datetime更改到另一个日期,您可以编写一个迁移来实现这一点。
你可以创建一个新的迁移:
rails g migration change_data_type_for_fieldname
然后编辑迁移,使用change_table:
class ChangeDataTypeForFieldname < ActiveRecord::Migration
def self.up
change_table :tablename do |t|
t.change :fieldname, :date
end
end
def self.down
change_table :tablename do |t|
t.change :fieldname, :datetime
end
end
end
然后运行迁移:
rake db:migrate
Rails 5
来自Rails指南:
如果你希望一个迁移做一些活动记录不知道如何反转的事情,你可以使用可逆:
class ChangeTablenameFieldname < ActiveRecord::Migration[5.1]
def change
reversible do |dir|
change_table :tablename do |t|
dir.up { t.change :fieldname, :date }
dir.down { t.change :fieldname, :datetime }
end
end
end
end
另一种改变数据类型的方法是使用迁移
步骤1: 您需要使用迁移删除错误的数据类型字段名
ex:
rails g migration RemoveFieldNameFromTableName field_name:data_type
这里不要忘记为字段指定数据类型
步骤2: 现在您可以使用正确的数据类型添加字段
ex:
rails g migration AddFieldNameToTableName field_name:data_type
就是这样,现在你的表将添加正确的数据类型字段,快乐的ruby编码!!
如果在一个表中有多个列要更改,也可以使用块。
例子:
change_table :table_name do |t|
t.change :column_name, :column_type, {options}
end
有关更多细节,请参阅关于Table类的API文档。