我们有script/generate migration add_fieldname_to_tablename fieldname:datatype语法,用于向模型添加新列。

在同一行中,是否有用于更改列的数据类型的脚本/generate ?或者我应该直接将SQL写入我的常规迁移中?

我想将一列从datetime改为date。


当前回答

我不知道您是否可以从命令行创建一个迁移来完成所有这些,但是您可以创建一个新的迁移,然后编辑迁移以执行这个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 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

另一种改变数据类型的方法是使用迁移

步骤1: 您需要使用迁移删除错误的数据类型字段名

ex:

rails g migration RemoveFieldNameFromTableName field_name:data_type

这里不要忘记为字段指定数据类型

步骤2: 现在您可以使用正确的数据类型添加字段

ex:

rails g migration AddFieldNameToTableName field_name:data_type

就是这样,现在你的表将添加正确的数据类型字段,快乐的ruby编码!!

正如我从前面的答案中发现的,改变列的类型需要三个步骤:

步骤1:

使用下面的代码生成一个新的迁移文件:

rails g migration sample_name_change_column_type

步骤2:

转到/db/migrate文件夹并编辑您创建的迁移文件。有两种不同的解决方案。

def变化 Change_column (:table_name,:column_name,:new_type) 结束

2.

    def up
        change_column :table_name, :column_name, :new_type
    end

    def down
        change_column :table_name, :column_name, :old_type
    end

步骤3:

不要忘记执行以下命令:

rake db:migrate

我已经在Rails 4上测试了这个解决方案,效果很好。

在编辑默认值的情况下完成回答:

在你的rails控制台:

rails g migration MigrationName

在迁移中:

  def change
    change_column :tables, :field_name, :field_type, default: value
  end

将看起来像:

  def change
    change_column :members, :approved, :boolean, default: true
  end

我不知道您是否可以从命令行创建一个迁移来完成所有这些,但是您可以创建一个新的迁移,然后编辑迁移以执行这个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