博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sql_mode=only_full_group_by
阅读量:5763 次
发布时间:2019-06-18

本文共 749 字,大约阅读时间需要 2 分钟。

今天同事重新安装的环境MySQL登陆的时候就提示报错信息如下:

SQLSTATE[42000]: Syntax error or access violation: 1055 Expression #1 of SELECT list is not in GROUP BY clause and containsnonaggregated column 'navibars.name' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

简单解释一下就是:我要查的navibars.name 列是非聚合的,这违背了sql的only_full_group_by 模式。这里就不贴数据表结构和sql语句了,只是简单解释一下错误原因。

当mysql分组后,出现有歧义的列时,比如下表:

code name status
a admin N
b guest N

select  name from 表 group by status;

在5.5版本中,会默认去第一条的name 即 admin,在5.7中就会报错,因为有这个分组里有两个不同的name,sql并不知道是哪个而你也没有声明,下面是MySQL高性能第三版关于这方面的阐述:

在分组查询的SELECT中直接使用非分组列(上表以status分组,但是用的是非分组列name)通常不是什么好主意,因为这样的结果通常是不定的,当索引改变,或者优化器选择不同的优化策略时都可能导致结果不一样。

解决思路:

1.修改代码

2.MySQL版本回退

3.修改SQL配置文件

转载地址:http://dxwux.baihongyu.com/

你可能感兴趣的文章
Oracle 备份与恢复学习笔记(5_1)
查看>>
Oracle 备份与恢复学习笔记(14)
查看>>
分布式配置中心disconf第一部(基本介绍)
查看>>
Scenario 9-Shared Uplink Set with Active/Active uplink,802.3ad(LACP)-Flex-10
查看>>
UML类图中的六种关系
查看>>
探寻Interpolator源码,自定义插值器
查看>>
一致性哈希
查看>>
mysql(待整理)
查看>>
看雪论坛502,出现安全宝?
查看>>
使用PullToRefresh实现下拉刷新和上拉加载
查看>>
mysql
查看>>
2012年电信业八大发展趋势
查看>>
Web日志安全分析工具 v2.0发布
查看>>
JS重载
查看>>
python2和python3同安装在Windows上,切换问题
查看>>
php加速工具xcache的安装与使用(基于LNMP环境)
查看>>
android超链接
查看>>
redhat tomcat
查看>>
统计数据库大小
查看>>
IO流的学习--文件夹下文件的复制
查看>>