mysql 8.0 添加only_full_group_by
时间: 2023-10-20 12:34:54 浏览: 125
在MySQL 8.0版本中,要添加only_full_group_by属性,可以通过以下方法实现:
1. 通过命令解决:可以使用以下命令在当前会话中设置only_full_group_by属性:
```
SET sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));
```
这将从当前会话中移除only_full_group_by属性,但在MySQL重新启动后会失效。
2. 修改配置文件:可以通过修改MySQL的配置文件来永久地设置only_full_group_by属性。打开my.cnf(或my.ini)配置文件,在[mysqld]节下添加如下行:
```
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
```
保存文件后,重新启动MySQL服务使更改生效。
请注意,以上方法仅适用于MySQL 8.0版本。希望对你有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
相关问题
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]
解决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的问题。
阅读全文