mysql - 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,"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 值。
可能您的开发环境允许默认值,而生产环境不允许。您可以升级生产系统或不使用该功能。
推荐阅读
- python - 使用 OpenTURNS 的连续和离散变量
- php - 无法加载 Symfony\Bridge\Doctrine\RegistryInterface
- r - 使用 cbind 后更改了列名
- .net - 为什么dotnet core publish命令不会将大写扩展文件复制到centos 7中的输出
- python - 如何在 TensorFlow 回归中指定 2 个或更多输出标签
- javascript - Angular Dom:- 将缺失的单元格(td)添加到 Angular 材质日历
- python - kmeans 数据上的 pca 图
- git - Bitbucket 服务器 - 在自动合并期间忽略某些文件
- c - 试图理解指针和线程
- r - 用 R 中唯一对应的平均值填充 NA