基于【 bug解决】一 || mysql的ONLY_FULL_GROUP_BY导致的sql语句错误

一、Mysql错误:

In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column ‘ynsl_new.u.user_id‘; this is incompatible with sql_mode=only_full_group_by

1、原sql语句:

SET @data_id=‘153f61e9727b450d8abbba5941e5085a‘;
SELECT
          u.*,
          GROUP_CONCAT(r.ROLE_CODE SEPARATOR ‘,‘) AS roleCode
      FROM
          tab_user u
          LEFT JOIN tab_user_role_relation ur ON ur.user_id = u.user_id
          LEFT JOIN tab_role r ON r.role_id = ur.role_id
      WHERE
          u.delete_mark = 0
          AND u.enable_mark = 1
          AND u.data_id = @data_id

  

2、中文大概意思:

在不带GROUP BY的聚合查询中,选择列表的表达式1包含未聚合的列“ynsl_new.u.user_id”;这与SQL_mode=only_full_group_by不兼容

也就是说,mysql的sql_mode是only_full_group_by的时候,在不使用group by 并且select后面出现聚集函数的话,那么所有被select的都应该是聚集函数,否则就会报错;

3、出现的原因:

在MySQL5.7.5后,默认开启了ONLY_FULL_GROUP_BY,所以导致了之前的一些SQL无法正常执行,其实,是我们的SQL不规范造成的,因为group by 之后,返回的一些数据是不确定的,所以才会出现这个错误。

二、解决方案:

1、关闭ONLY_FULL_GROUP_BY

在配置文件中,找到sql_mode,去掉only_full_group_by

2、规范sql语句,使用group by

SET @data_id=‘153f61e9727b450d8abbba5941e5085a‘;
SELECT
          u.*,
          GROUP_CONCAT(r.ROLE_CODE SEPARATOR ‘,‘) AS roleCode
      FROM
          tab_user u
          LEFT JOIN tab_user_role_relation ur ON ur.user_id = u.user_id
          LEFT JOIN tab_role r ON r.role_id = ur.role_id
      WHERE
          u.delete_mark = 0
          AND u.enable_mark = 1
          AND u.data_id = @data_id
      GROUP BY u.user_id ;

  

原文地址:https://www.cnblogs.com/kevin-ying/p/11601809.html

时间: 2024-11-05 00:42:25

基于【 bug解决】一 || mysql的ONLY_FULL_GROUP_BY导致的sql语句错误的相关文章

如何在mysql查找效率慢的SQL语句

如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow-queries[=file_name]选项启动时,mysqld 会写一个包含所有执行时间超过long_query_time 秒的SQL语句的日志文件,通过查看这个日志文件定位效率较低的SQL .下面介绍MySQL中如何查询慢的SQL语句 一.MySQL数据库有几个配置选项可以帮助我们及时捕获低效SQL语句 1,slow_query_log 这

mysql 删除重复数据的sql语句

CREATE TABLE tmp AS SELECT id FROM get_review_url WHERE (no,title,name,content) IN (SELECT no,title,name,content FROM get_review_url GROUP BY no,title,name,content HAVING COUNT(*) > 1) AND id NOT IN (SELECT MIN(id) FROM get_review_url GROUP BY no,tit

在MySQL命令行中使用SQL语句的规则

规则1: SQL语句必须以分号(;)或者(\G)结束 分号(;)是SQL语句的结束标志.如果遗忘了分号,而直接按下回车键时,在MySQL客户端上将显示如下 mySQL> SELECT * FROM customer -> 因为没有以分号结束,客户端认为SQL语句并没有结束,显示[->]等待用户继续输入命令,直到以分号结束.有些数据库中,支持省略最后的分号的情况. 规则2: 保留关键字不区分大小写 保留关键字是SQL中事先定义好的关键字,如上面检索语句中的SELECT.FROM等就属于保留

如何查找MySQL中查询慢的SQL语句

本文导读:如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow-queries[=file_name]选项启动时,mysqld 会写一个包含所有执行时间超过long_query_time 秒的SQL语句的日志文件,通过查看这个日志文件定位效率较低的SQL .下面介绍MySQL中如何查询慢的SQL语句 一.MySQL数据库有几个配置选项可以帮助我们及时捕获低效SQL语句 1,slow_query_

MySQL表横纵转置Sql语句

id, student, course, mark 1,  张三,    语文,  90 2,  李四,    语文,  80 3,  张三,    数学,  70 4,  李四,    数学,  80 现在想用转置表的方法转成二维表输出,要求格式是: student, 语文, 数学 张三,    90,  70 李四,    80,  80 select student,     sum(if(course='语文',mark,0)) as 语文,     sum(if(course='数学'

MySql命令行命令和SQL语句

一.常用mysql命令行命令 1.启动MYSQL服务 net start mysql 停止MYSQL服务 net stop mysql 2.netstat -na|findstr 3306 查看被监听的端口,findstr用于查找后面的端口是否存在 3.在命令行中登录MYSQL控制台,即使用MYSQL COMMEND LINE TOOL 语法格式 mysql -user=root  -password=123456  db_name 或者简写格式 mysql -uroot -p123456 db

Navicat for MySQL界面下如何用SQL语句创建表?

Navicat for MySQL界面下如何用SQL语句创建表?下面小编就告诉你.首先打开 Navicat,选择一个数据库,点击"查询",在右侧点击"创建查询",输入SQL语句,点击"执行"就可以了,示例SQL: CREATE TABLE `test`.`users` ( `id` int(10) NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFAULT NULL, `age` int(10) DEF

2.MySQL用户管理,常用SQL语句,MySQL数据库备份与恢复

[toc] MySQL用户管理,重用SQL语句,MySQL数据库备份与恢复 一.MySQL用户管理 1.创建一个普通用户并授权 首先启动mysql,然后进入 [[email protected] ~]# /etc/init.d/mysqld start Starting MySQL... SUCCESS! [[email protected] ~]# mysql -uroot -pxavilinux Warning: Using a password on the command line in

MySQL客户端工具以及常用SQL语句

Mysql客户端工具: 在用yum安装的maiadb-server的时候,在/etc/my.cnf.d下有一个名为client.cnf的文件,编辑此文件,在此文件的[client]下添加用户名和密码就可以不用输入口令登录 vim /etc/my.cnf.d/client.cnf [client] user=root # 登录数据库使用的用户名 password=mysql #登录数据库使用的密码 大部分常用SQL语句 1 创建用户并查看(SQL语句); create user [email pr