mysql 出现in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by问题

部署项目使用到了mysql 5.7.x版本时出现以下问题

Caused by: java.sql.SQLSyntaxErrorException: Expression #1 of SELECT type is not in GROUP BY clause and contains nonaggregated column ‘Tuser_type’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

意思是select 查询的列表达式不在GONLY_FULL_GROUP_BY,GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP
BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中

由于MySQL提供的一个sql_mode,通过这个sql_mode来提供SQL语句GROUP BY合法性的检查,在MySQL的sql_mode是非ONLY_FULL_GROUP_BY语义时。一条select语句,MySQL允许target list中输出的表达式是除聚集函数或group by column以外的表达式,这个表达式的值可能在经过group by操作后变成undefined。也就是说只能返回count(*)等参数了。如何解决:此处有两种方法:一种就是直接修改数据的sql_mode:另一种是直接修改mysql中的my.cnf(或者my.ini)

解决方法:

第一种:直接修改数据的sql_mode:

登陆数据库 查看sql_mode :

select @@sql_mode

设置sql_mode :

SET @@global.sql_mo

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值