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 值。

可能您的开发环境允许默认设置,而生产环境不允许。您可以升级生产系统,也可以不使用该功能。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...