请回答我MySQL8.0如何解决 sql_mode=only_full_group_by 不兼容
时间: 2023-09-21 22:02:49 浏览: 73
的问题。
MySQL8.0 可以通过设置新的 sql_mode 参数来解决 sql_mode=only_full_group_by 不兼容的问题。具体做法是在 MySQL 配置文件中添加以下代码:
```
[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
```
在新的 sql_mode 中增加了 NO_ENGINE_SUBSTITUTION,表示禁止在不支持存储引擎时使用默认的存储引擎进行替换。这样就可以避免出现 sql_mode=only_full_group_by 不兼容的问题了。
相关问题
解决docker mysql 8.0 遇到sql_mode=only_full_group_by的问题
解决docker mysql 8.0遇到sql_mode=only_full_group_by的问题,可以按照以下步骤进行操作:
1. 首先,查看当前的sql_mode配置,可以使用以下命令查询:SELECT @@GLOBAL.sql_mode; [1]
2. 复制查询结果字符串,并去掉其中的only_full_group_by选项。例如,如果查询结果为STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION,那么去掉only_full_group_by后的结果就是STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION。
3. 找到mysql的配置文件my.cnf,一般位于/etc/my.cnf路径,如果有自定义路径,可以进入自定义路径。
4. 进入配置文件,找到[mysqld]下的sql-mode配置项,如果没有则手动添加。将步骤2中得到的结果添加到sql-mode配置项中,例如:sql-mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION。
5. 保存配置文件,并重启mysql服务。如果是使用docker安装的mysql,可以使用docker restart命令重启容器。例如:docker restart 容器id。[1]
另外,如果你是第一次使用docker安装mysql 8.0,可以按照以下步骤进行操作:
1. 拉取mysql 8.0版本的镜像,并启动容器并做端口映射。可以使用以下命令拉取镜像并启动容器:docker pull mysql:8.0 和 docker run -p 3306:3306 --name mysql8 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:8.0。[2]
2. 进入容器,可以使用以下命令进入容器:docker exec -it mysql bash。
3. 在容器中设置初始密码,可以使用以下命令:ALTER USER 'root' IDENTIFIED WITH mysql_native_password BY '123456';[3]
4. 重启容器,可以使用以下命令重启容器:docker restart mysql8。[3]
通过以上步骤,你应该能够成功解决docker mysql 8.0遇到sql_mode=only_full_group_by的问题。
docker mysql 8.0 遇到sql_mode=only_full_group_by的问题
鉴于您的问题是关于docker mysql 8.0遇到sql_mode=only_full_group_by的问题,根据引用[1]中提供的信息,这个问题是由于mysql配置文件中的sql_mode字段包含了only_full_group_by导致的。解决这个问题的方法是通过修改mysql配置文件来去掉only_full_group_by。首先,您可以使用命令SELECT @@GLOBAL.sql_mode;来查看当前的sql_mode配置。然后,复制查询结果字符串并去掉only_full_group_by这一部分。接下来,找到mysql配置文件my.cnf,一般在/etc/my.cnf路径下,如果您有自定义路径,可以在自定义路径下找到。进入配置文件后,在mysqld下增加sql-mode配置,将刚刚复制并修改过的查询结果字符串粘贴到sql-mode = 后面。保存并重启mysql服务,如果您是使用docker安装的,可以使用docker restart命令来重启容器。[1]
另外,如果您是在安装docker mysql 8.0时遇到了问题,可以参考引用[2]中提供的步骤来拉取mysql 8.0镜像并启动容器。如果您需要进入容器进行操作,可以使用docker exec命令进入容器。在容器中,您可以使用ALTER USER命令来设置初始密码,然后使用docker restart命令重启容器。[2][3]
阅读全文