如何解决Mysql 错误 BLOB、TEXT、GEOMETRY 或 JSON 列不能有默认值
我的 vps linux ubuntu 是 服务器类型:MysqL 服务器版本:5.7.33 ubuntu0.18.04.1 - (Ubuntu) Apache/2.4.29 (Ubuntu) 数据库客户端版本:libMysqL - MysqLnd 5.0.12-dev - 20150407 - PHP 版本:7.2.24-
试图在我的数据库中添加一列但我收到错误 我在 windows xampp 上试过它的工作没有任何问题
ALTER TABLE users ADD COLUMN house LONGTEXT NOT NULL DEFAULT '{"owns":false,"furniture":[],"houseId":0}';
sql query:
ALTER TABLE users ADD COLUMN house LONGTEXT NOT NULL DEFAULT '{"owns":false,"houseId":0}'
MysqL said: Documentation
#1101 - BLOB,TEXT,GEOMETRY or JSON column 'house' can't have a default value
解决方法
我猜您的本地 XAMPP 开发服务器正在运行 MySQL 8.0.13 或更高版本,或者 MariaDB 10.2.1 或更高版本。在该版本之前,MYSQL 不允许 JSON 列使用除 NULL 以外的 DEFAULT 值。在 MariaDB 中,JSON 是 LONGTEXT 的别名,同样(从版本 10.2.1 开始)允许使用 DEFAULT 值。
可能您的开发环境允许默认设置,而生产环境不允许。您可以升级生产系统,也可以不使用该功能。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。