mysql8.0 sql_mode=only_full_group_by
时间: 2023-11-11 19:00:16 浏览: 83
MySQL 8.0 中的 sql_mode=only_full_group_by 是什么意思?
在 MySQL 8.0 中,sql_mode=only_full_group_by 是一种严格模式,它要求 GROUP BY 子句中的每个列都必须在 SELECT 列表中出现,或者是聚合函数的参数。如果不满足这个条件,MySQL 就会抛出错误。
这个严格模式的目的是为了避免在 GROUP BY 查询中出现意外的结果。在早期版本的 MySQL 中,如果 GROUP BY 子句中的列不在 SELECT 列表中出现,MySQL 会随机选择一个值作为结果。这种行为可能会导致查询结果不准确,因此 MySQL 8.0 引入了这个严格模式。
相关问题
sql_mode=only_full_group_by mysql 8.0
在MySQL 8.0中,sql_mode=only_full_group_by是一种SQL模式,它使得在执行GROUP BY时,SELECT列表中的非聚合列必须出现在GROUP BY子句中。这是为了确保查询结果的准确性和一致性。然而,这也可能导致一些查询出错,例如在SELECT列表中包含了非聚合列并且没有在GROUP BY子句中列出。引用
要解决这个问题,有两种方法可以尝试。首先,你可以修改全局设置,这样对于新建的数据库会有效。你可以执行以下命令:SET @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'; 引用
另外,如果你想对已存在的数据库生效,你需要在对应的数据库下执行以下命令:SET sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'; 引用
举个例子,如果你想在mt_user表中根据mobile字段进行分组,并且只显示那些mobile字段的值重复超过一次的记录,你可以执行以下查询:select id,mobile from mt_user group by mobile having count(1)>1; 但是,由于sql_mode设置为only_full_group_by,这个查询会报错,因为SELECT列表中的id字段没有在GROUP BY子句中列出。引用
因此,为了解决这个问题,你可以按照上述方法修改sql_mode设置,将only_full_group_by从中移除。这样就可以执行这个查询并得到正确的结果了。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [MySQL 8.0 修改 sql_mode=only_full_group_by](https://blog.csdn.net/qq_35349114/article/details/108277591)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
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]