【问题标题】:Mysql error BLOB, TEXT, GEOMETRY or JSON colum cant have default valueMysql错误BLOB、TEXT、GEOMETRY或JSON列不能有默认值
【发布时间】:2021-02-22 07:36:48
【问题描述】:

我的 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,"furniture":[],"houseId":0}'
MySQL said: Documentation

#1101 - BLOB, TEXT, GEOMETRY or JSON column 'house' can't have a default value

【问题讨论】:

标签: mysql phpmyadmin


【解决方案1】:

我猜你的本地 XAMPP 开发服务器正在运行 MySQL 8.0.13 或更高版本,或者 MariaDB 10.2.1 或更高版本。在该版本之前,MYSQL 不允许 JSON 列使用除 NULL 以外的 DEFAULT 值。在 MariaDB 中,JSON 是 LONGTEXT 的别名,同样(从版本 10.2.1 开始)允许使用 DEFAULT 值。

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

【讨论】:

    【解决方案2】:

    移除默认值:

    ALTER TABLE users ADD COLUMN house LONGTEXT NOT NULL;
    

    【讨论】:

      猜你喜欢
      • 2018-11-21
      • 2016-11-20
      • 1970-01-01
      • 2018-04-02
      • 1970-01-01
      • 1970-01-01
      • 2015-03-16
      • 1970-01-01
      • 2013-03-04
      相关资源
      最近更新 更多