浅谈mysql的sql_mode可能会限制你的查询

 更新时间:2025年03月28日 11:31:38   作者:秋刀prince  
本文主要介绍了浅谈mysql的sql_mode可能会限制你的查询,这个问题主要说明的是,我们写的sql查询语句违背了聚合函数group by的规则,下面就来介绍一下解决方法,感兴趣的可以了解一下

场景:

现在我们常用数据库有哪些?一想到的就是mysql,oracle吧,今天说的是mysql中我们写sql语句时候常见的一个问题,相信挺多朋友在执行一些复杂的分组查询的时候,都会遇到一个查询错误,大佬们自然不存在了,但相信小猿们还是会碰到的;

错误内容大致为:

Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated 
column '某列字段' which is not functionally dependent on columns in GROUP BY clause; 
this is incompatible with sql_mode=only_full_group_by

问题描述

这个问题主要说明的是,我们写的sql查询语句违背了聚合函数group by的规则,他要求SELECT列表中的所有列都必须是聚合函数的参数或者包含在GROUP BY子句中;简单的说,也就是select后的字段列,和group by 之后的字段列没有对应上。

原因分析:

提示:为什么会出现这个问题呢?我们会好奇,好像以前执行这个类似的查询的时候没有这种限制啊,问题就在于mysql的sql_mode变量的设置有关;但是这个只针对5.7版本之后的mysql,若大家还在用早期的mysql的话,不会有这个问题,这个是后面版本加的强制规范模式;

什么是sql_mode,sql_mode 是一个用于控制 MySQL 服务器操作模式的系统变量。它允许用户定义 SQL 语言语法、数据校验和存储引擎行为的一些规则。通过设置不同的 sql_mode 值,你可以定制 MySQL 服务器的行为,以符合特定的 SQL 标准、增强数据完整性或满足特定的应用需求

解决方案:

问题找到了,我们就来验证一下是不是sql_mode的设置有问题;

查询mysql的sql_mode变量值

// 在navicat中,查询语句输入
// 没有navicat的也可以直接dos进入命令行登录mysql后,输入语句也是一样的
select @@global.sql_mode

在这里插入图片描述

在结果中,我们可以看到有ONLY_FULL_GROUP_BY的内容,说明在数据库中我们设置了该语法的强制校验规则,所以导致我们的查询不通过。因此,我们只要将这个值去掉即可;
修改该变量值通常的做法有两个方式:

第一种:修改后,只有当前生效,若是mysql服务重启,就会失效;

//  set global sql_mode = 'select @@global.sql_mode 得到返回值中,去掉group by 限制'

set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

在这里插入图片描述

第二种:需要修改mysql的配置文件;但是效果则是永久的;

我们只要找到我们的mysql配置文件即可,打开在【mysqld】下加上一句话;
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION设置后需要重启mysql服务才会生效;

这里需要注意的是,若是windows系统,配置文件找到my.ini修改即可,但若是跟博主一样的mac电脑,则是找到my.cnf,有时候可能也叫(mysql-deafault.cnf)甚至有的版本并不会生成这个配置文件,需要我们自行生成,具体根据安装mysql的方式有关系,你用homebrew和正常dmg安装的就不一样,所以这块一定要注意别找错配置文件,不然配置就不会生效

不得不吐槽一下mac电脑,已经很难了,如果你还是macos加个M1,M2芯片,那对味了,看一眼就爆炸

到此这篇关于浅谈mysql的sql_mode可能会限制你的查询的文章就介绍到这了,更多相关mysql sql_mode查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决Mysql5.7中文乱码的问题

    解决Mysql5.7中文乱码的问题

    在使用mysql5.7时,会发现通过web端向数据库中写入中文后会出现乱码,但是在数据库中直接操作SQL语句插入数据后中文就显示正常,这个问题怎么解决呢,下面小编给大家分享下解决方案
    2017-03-03
  • mysql嵌套查询和联表查询优化方法

    mysql嵌套查询和联表查询优化方法

    本文描述了mysql嵌套查询和联表查询优化的方法,有些情况可以使用这种优化方法,而有些情况,这种方法就无能为力了
    2013-02-02
  • MySQL 分表优化试验代码

    MySQL 分表优化试验代码

    我们的项目中有好多不等于的情况。今天写这篇文章简单的分析一下怎么个优化法。
    2010-04-04
  • MySQL优化常用的19种有效方法(推荐!)

    MySQL优化常用的19种有效方法(推荐!)

    关于数据库优化,网上有不少资料和方法,但是不少质量参差不齐,有些总结的不够到位,内容冗杂,下面这篇文章主要给大家介绍了关于MySQL优化常用的19种有效方法,需要的朋友可以参考下
    2022-03-03
  • MySQL中日期和时间戳互相转换的函数和方法

    MySQL中日期和时间戳互相转换的函数和方法

    这篇文章主要介绍了MySQL中日期和时间戳互相转换的函数和方法,本文分别讲解了时间戳转换成日期的方法和把日期转换为时间戳的方法,需要的朋友可以参考下
    2015-06-06
  • mysql如何实现最大连接数

    mysql如何实现最大连接数

    云服务器同时最大连接数,也就是说可以有一千个用户,那么mysql如何实现最大连接数,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • MySQL的联表查询实现

    MySQL的联表查询实现

    数据通常分布在多个表中,为了获取全面的信息,需要进行联表查询,本文主要介绍了MySQL的联表查询实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-08-08
  • 浅析Mysql 中如何导出数据

    浅析Mysql 中如何导出数据

    MySQL中你可以使用SELECT…INTO OUTFILE语句来简单的导出数据到文本文件上,这篇文章给大家介绍了Mysql 中如何导出数据,感兴趣的朋友跟随小编一起看看吧
    2023-11-11
  • 眼见不一定为实之MySQL中的不可见字符详解

    眼见不一定为实之MySQL中的不可见字符详解

    这篇文章主要给大家介绍了关于眼见不一定为实之MySQL中不可见字符的相关资料,不可见字符是指在文本中无法直接显示出来的字符,它们通常用于控制文本的格式或布局,需要的朋友可以参考下
    2024-06-06
  • mysql 如何插入随机字符串数据的实现方法

    mysql 如何插入随机字符串数据的实现方法

    这篇文章主要介绍了mysql 如何插入随机字符串数据的实现方法,需要的朋友可以参考下
    2016-09-09

最新评论