MySQL GROUP BY 报错-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

MySQL GROUP BY 报错

简介: 版权声明:本文首发 http://asing1elife.com ,转载请注明出处。 https://blog.csdn.net/asing1elife/article/details/82892955 ...
版权声明:本文首发 http://asing1elife.com ,转载请注明出处。 https://blog.csdn.net/asing1elife/article/details/82892955

使用 GROUP BY 时抛出 only_full_group_by 异常

更多精彩

问题

  1. 通过 GROUP BY 查询时抛出下列异常
Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'xxx' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

解决

  1. 设置全局 sql_mode
SET GLOBAL sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
  1. 查询设置结果 SELECT @@GLOBAL.sql_mode;
  2. 在可视化工具中通过 SET GLOBAL sql_mode 设置的结果只在会话中生效,数据库重启后则失效
  3. 想要设置 sql_mode 全局生效则需要在 mysql 的 my.cnf 文件中填写 sql_mode
  4. 通过 homebrew 安装 mysql 后,在 /etc 目录下默认没有创建 my.cnf 文件,需要自行创建 cp /usr/local/opt/mysql/support-files/my-default.cnf /etc/my.cnf
  5. 进入到 _etc_my.cnf 文件中,在最后输入 sql_mode
  6. 重启 mysql

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: