mysql 配置引起的报错

由于最近做mysql版本的升级,为了测试兼容性,部署了另一个高版本的mysql服务,测试过程中发现有些问题

(1)一些查询报错,用group by的

sql_mode设置的不同

新实例有个ONLY_FULL_GROUP_BY需要去掉!而且新版本是8*,不支持 NO_AUTO_CREATE_USER这个模式,也需要去掉。

java 复制代码
NO_AUTO_CREATE_USER 是一个已废弃的 SQL 模式选项,在早期的 MySQL 版本中用于控制 GRANT 语句的行为。当这个模式被激活时,它会阻止 GRANT 
语句自动创建不存在的用户账户,除非在授予权限的同时也指定了用户的密码。这意味着,如果你尝试为一个尚不存在的用户授予权限,
而且没有提供密码,MySQL 不会自动创建这个用户,而是会失败或者忽略这个请求。

例如,如果你执行如下 GRANT 语句:

GRANT SELECT ON database.* TO 'newuser'@'localhost';

在 NO_AUTO_CREATE_USER 模式下,如果 'newuser'@'localhost' 这个用户之前不存在,并且没有同时提供一个密码,
这个命令将会失败,以防止无意识地创建用户账户。

然而,从 MySQL 8.0.11 开始,包括 NO_AUTO_CREATE_USER 在内的几个与账户管理相关的旧特性已被移除,因此在 MySQL 8.0 及以后的版本中,
你不再需要也不应该使用 NO_AUTO_CREATE_USER 这个模式选项。在这些新版本中,如果想要创建用户并授予权限,
必须明确地使用 CREATE USER 语句创建用户,然后再使用 GRANT 语句分配权限,并且在创建用户时提供密码。

(2)插入报错,timestamp类型的字段设置的都是NOT NULL,旧实例插入成功,新实例失败

查了下2个实例对于 explicit_defaults_for_timestamp 这个参数配置不同,旧实例是OFF状态,高版本实例是ON状态,高版本也关闭该配置即可兼容

参考

https://cloud.tencent.com/developer/article/1408102

相关推荐
数据知道7 分钟前
FastAPI项目:从零到一搭建一个网站导航系统
python·mysql·fastapi·python web·python项目
Leon-Ning Liu39 分钟前
MySQL 5.7大表索引优化实战:108GB数据建索引效率提升50%
运维·数据库·mysql
千寻技术帮1 小时前
50030_基于微信小程序的生鲜配送系统
mysql·微信小程序·源码·安装·文档·ppt·答疑
Wang's Blog1 小时前
MySQL: 数据库监控核心要素与实施策略
数据库·mysql
海奥华22 小时前
分库分表技术详解:从入门到实践
数据库·后端·mysql·golang
就是ping不通的蛋黄派4 小时前
MySQL数据库 管理与维护
数据库·mysql
找不到、了14 小时前
MySQL 索引下推(ICP)的实战,彻底提升查询性能
数据库·mysql
kitty_hi14 小时前
mysql主从配置升级,从mysql5.7升级到mysql8.4
linux·数据库·mysql·adb
q***133416 小时前
Linux系统离线部署MySQL详细教程(带每步骤图文教程)
linux·mysql·adb
计算机毕业设计小途17 小时前
计算机毕业设计推荐:基于springboot的快递物流仓库管理系统【Java+spring boot+MySQL、Java项目、Java毕设、Java项目定制定
java·spring boot·mysql