mysql使用group by出现1055报错 mac环境

mysql使用group by出现1055报错 mac环境

mysql> select * from emp group by gender;
ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'db01.emp.id' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

之所以说这种查找方式不合理,是因为ONLY_FULL_GROUP_BY这个属性是规定了查找的位置只能是group by后面的那个字段,如果你select 后面涉及到其他字段,就会出错,你select 后面能加其他的字段必须是聚合函数或者是group by 后面的那个字段。

分析原因:

终端登录MySQL,输入并执行:select @@global.sql_mode;

得到:

+-----------------------------------------------------------------------------------------------------------------------+
| @@global.sql_mode                                                                                                     |
+-----------------------------------------------------------------------------------------------------------------------+
| ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION |
+-----------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

出错原因,因为默认开了ONLY_FULL_GROUP_BY这个属性,和想要执行的group by 方式相冲突。

解决方法:

将ONLY_FULL_GROUP_BY这个属性去掉:

上面查看了属性有这些:

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

之所以按照上面的做,因为你的属性可能和我不完全一样,所以直接复制我的代码有可能不成功。

然后将这一段代码放到下面这段的’ '里

执行下行代码(如果出错,要按照上面所说的,根据自己终端查到的属性,把’ ’ 里面的改一下):

set global sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

最后你得输入exit或者quit退出一下mysql的客户端,然后重新登录一次,本次设置才会生效。

需要说明的是 这个设置 并不是永久有效的 服务端重启就还原 只是测试查看一下
最好不要使用select * from table名 group by post; 这种查找方式。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值