[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated解决

今天在docker容器中搭建mysql主从同步的时候,发现了如下报错:
[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated

问题背景:
使用的mysql数据库版本为:5.7
在从库中执行如下命令:start slave

然后就报如上错误

[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column ‘information_schema.PROFILING.SEQ’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

分析原因

这个问题主要是由于sql_mode引起,所以先查看sql_mode后修改即可,主要是去除only_full_group_by

解决方案:

通过mysql客户端连接数据库。比如navicat、sqlyog等,运行如下命令:
SELECT @@sql_mode;
可以看到查询结果为:
在这里插入图片描述
上面的这个查询结果是执行修改了SQL_MODE之后的查询结果,实际在还没有修改之前里面应该有only_full_group_by,然后修改SQL_MODE的值即可,运行如下命令:
SET sql_mode=(SELECT REPLACE(@@sql_mode,‘ONLY_FULL_GROUP_BY’,’’));

当再次执行start slave命令的时候,则mysql就不会再报上面那个错误了。

本次出行的这个错误是在docker容器中出现的,如果是使用的mysql安装包安装的mysql,则需要去修改配置文件my.ini

在my.ini中添加如下配置:
[mysql]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

可以看出,这个跟上面最终的查询结果一致:
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值