gpt4 book ai didi

ruby-on-rails - 添加适用于 MySQL 的默认 bool 值的正确方法是什么?

转载 作者:行者123 更新时间:2023-12-03 00:50:41 27 4
gpt4 key购买 nike

我已经在生产服务器上运行了迁移,并且正在使用 MySQL,但收到此错误:

Mysql2::Error: Invalid default value for 'admin': ALTER TABLE users ADD admin tinyint(1) DEFAULT 'false'`

我的迁移如下所示:

class AddAdminToUsers < ActiveRecord::Migration
def change
add_column :users, :admin, :boolean, default: :false
end
end

我理解这个错误是因为“false”不是tinyint的正确值,在这种情况下应该是0。我认为 default: :false 是将 bool 值默认为 false 的正确方法。

如何解决这个问题,以便 MySQL 不会提示错误值?

最佳答案

false 不是我相信的符号。试试这个

add_column :users, :admin, :boolean, default: false

PS我错了。所以你应该设置 default: 0 :(。或者你可以修补 ActiveRecord::Migration 以便它接受 true|false

关于ruby-on-rails - 添加适用于 MySQL 的默认 bool 值的正确方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9605573/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com