我在以前的迁移中创建了一个日期列,并将其设置为可空。现在我想把它改成非空。假设数据库中有空行,我该怎么做呢?我可以把这些列设置为时间。现在如果它们是空的。
当前回答
创建一个迁移,它有一个change_column语句,值为:default =>。
change_column :my_table, :my_column, :integer, :default => 0, :null => false
看:change_column
根据数据库引擎的不同,您可能需要使用change_column_null
其他回答
在Rails 4中,这是一个更好的(dry)解决方案:
change_column_null :my_models, :date_column, false
为了确保该列中不存在NULL值的记录,您可以传递第四个参数,这是用于NULL值记录的默认值:
change_column_null :my_models, :date_column, false, Time.now
Rails 4:
def change
change_column_null(:users, :admin, false )
end
如果你在迁移中这样做,那么你可能会这样做:
# Make sure no null value exist
MyModel.where(date_column: nil).update_all(date_column: Time.now)
# Change the column to not allow null
change_column :my_models, :date_column, :datetime, null: false
在Rails 4.02+中,根据文档,没有像update_all这样带有2个参数的方法。相反,你可以使用下面的代码:
# Make sure no null value exist
MyModel.where(date_column: nil).update_all(date_column: Time.now)
# Change the column to not allow null
change_column :my_models, :date_column, :datetime, null: false
创建一个迁移,它有一个change_column语句,值为:default =>。
change_column :my_table, :my_column, :integer, :default => 0, :null => false
看:change_column
根据数据库引擎的不同,您可能需要使用change_column_null
推荐文章
- 如何确定一个数组是否包含另一个数组的所有元素
- Rails find_or_create_by多个属性?
- Rails ActiveRecord日期之间
- 是什么导致这个ActiveRecord::ReadOnlyRecord错误?
- Rails:dependent =>:destroy VS:dependent =>:delete_all
- 对于PostgreSQL表来说,多大才算太大?
- Rails:如何在Rails 4中引用CSS中的图像
- 如何使用RSpec的should_raise与任何类型的异常?
- Rails -嵌套包括活动记录?
- Delete_all vs destroy_all
- Rails获取“each”循环的索引
- 在rails redirect_to中传递参数
- Rails new vs create
- Rails has_many的别名
- 使用Django South进行向后迁移