this is incompatible with sql_mode=only_full_group_by mac brew
时间: 2023-10-30 17:05:28 浏览: 98
在Mac上使用Homebrew安装的MySQL,如果出现"this is incompatible with sql_mode=only_full_group_by"的错误,可以按照以下步骤解决:
1. 关闭MySQL服务:在终端执行命令`brew services stop mysql@5.7`
2. 编辑MySQL配置文件:在终端执行命令`vi /usr/local/etc/my.cnf`打开MySQL配置文件
3. 在配置文件中添加以下内容,以禁用sql_mode中的only_full_group_by模式:
```
[mysqld]
sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
```
4. 保存并退出MySQL配置文件:按下Esc键,然后输入`:wq`,然后按回车键。
5. 启动MySQL服务:在终端执行命令`brew services start mysql@5.7`
这样,你就成功解决了"this is incompatible with sql_mode=only_full_group_by"错误,并且MySQL服务已经重新启动。
相关问题
; this is incompatible with sql_mode=only_full_group_by
错误 "this is incompatible with sql_mode=only_full_group_by" 表示在使用group by时出现了不兼容sql_mode=only_full_group_by模式的情况。 这个错误通常是由于SELECT语句中的表达式不在GROUP BY子句中,并且包含了未在GROUP BY子句中的非聚合列所引起的。
要解决这个错误,你可以按照以下步骤操作:
1. 确保你的SQL查询语句遵循当前的only_full_group_by模式。这意味着所有未在GROUP BY子句中的列应该使用聚合函数进行包裹,或者不在SELECT语句中选择未在GROUP BY子句中的列。
2. 对于Linux系统,在my.conf配置文件的[mysqld]标签末尾添加sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION。这样可以关闭only_full_group_by模式,以兼容不符合该模式的查询语句。
通过以上操作,你应该能够解决错误 "this is incompatible with sql_mode=only_full_group_by"。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *3* [MySQL sql_mode=only_full_group_by错误、my.cnf修改后不起作用问题解决方案,全再现](https://blog.csdn.net/huaishitou/article/details/119759337)[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: 50%"]
- *2* [MySQL错误-this is incompatible with sql_mode=only_full_group_by完美解决方案](https://blog.csdn.net/u012660464/article/details/113977173)[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: 50%"]
[ .reference_list ]
GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
GROUP BY子句用于将结果集按照一个或多个列进行分组。然而,在MySQL 5.7.5之后的版本中,默认启用了sql_mode=only_full_group_by模式,该模式要求SELECT列表中的非聚合列必须出现在GROUP BY子句中。如果不满足这个要求,就会出现"Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column"的错误。
解决这个问题的方法有两种:
1. 将sql_mode设置为非only_full_group_by模式。可以通过以下步骤来实现:
- 打开MySQL配置文件(my.cnf或my.ini)。
- 在[mysqld]部分添加或修改sql_mode参数,将其设置为空字符串或其他不包含only_full_group_by的模式。
- 保存并重启MySQL服务。
2. 修改查询语句,将非聚合列添加到GROUP BY子句中。例如,如果查询语句是SELECT列1, 列2, 聚合函数(...) FROM 表名 GROUP BY 列1,可以将其修改为SELECT 列1, 列2, 聚合函数(...) FROM 表名 GROUP BY 列1, 列2。
下面是两种解决方法的示例代码:
1. 修改sql_mode:
```shell
# 打开MySQL配置文件
vi /etc/mysql/my.cnf
# 在[mysqld]部分添加或修改sql_mode参数
sql_mode=""
# 保存并退出
:wq
# 重启MySQL服务
service mysql restart
```
2. 修改查询语句:
```sql
SELECT 列1, 列2, 聚合函数(...)
FROM 表名
GROUP BY 列1, 列2
```
阅读全文
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)