我的 vps linux ubuntu 是
Server type: MySQL
Server version: 5.7.33 ubuntu0.18.04.1 - (Ubuntu)
Apache/2.4.29 (Ubuntu)
Database client version: libmysql - mysqlnd 5.0.12-dev - 20150407 -
PHP version: 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,"furniture":[],"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 值。
可能您的开发环境允许默认值,而生产环境则不允许。您可以升级生产系统或不使用该功能。
删除默认值:
ALTER TABLE users ADD COLUMN house LONGTEXT NOT NULL;