[已解决] MySQL: Error Code: 3065和Error Code: 1055

news/2024/11/25 13:12:16/

文章目录

  • 环境
  • 问题
  • 分析
  • 解决
  • 方法一
  • 方法二
  • 扩展
    • sql_mode属性含义
    • sql_mode 三种作用域

环境

windows系统

问题

程序运行时遇到下面的问题:

Error Code: 3065
Expression #1 of ORDER BY clause is not in SELECT list, references column 'xxxx' which is not in SELECT list; this is incompatible with DISTINCT
Error Code: 1055
Expression #15 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'xxxx' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

分析

  1. 查看当前使用的MySQL版本:

    SELECT VERSION();
    

    查询结果为:5.7.30

  2. 查询sql_mode:

    select @@global.sql_mode;查询sql_mode,本地优先级最高
    select @@sql_mode或者
    SHOW VARIABLES LIKE 'sql_mode%';
    

    查询结果为:
    ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

    换了一个5.6 版本的MySQL数据库,查询sql_mode,结果如下:
    STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

分析发现,MySQL 5.7 多了很多限制。

解决

解决方法:
去除ONLY_FULL_GROUP_BY

方法一

通过命令:设置全局的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';

设置session级别的的sql_mode,不用加上面的global。

注意,该方法在重启Mysql服务后会失效,重启服务后会失效

方法二

修改mysql的配置文件,来关闭ONLY_FULL_GROUP_BY SQL模式

先停止mysql windows 服务

net stop mysql

打开本地的MySQL 配置文件:

修改:
[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

保存并启动mysql服务

net start mysql

扩展

sql_mode属性含义

  1. ONLY_FULL_GROUP_BY
    这个模式会对 GROUP BY 进行合法性检查,对于 GROUP BY 操作,如果在SELECT 中的列,没有在 GROUP BY 中出现,那么将认为这个 SQL 是不合法的,因为列不在 GROUP BY 从句中
  2. STRICT_TRANS_TABLES
    这就是严格模式,在这个模式下会对数据进行严格的校验,错误数据不能插入,报error 错误。如果不能将给定的值插入到事务表中,则放弃该语句。对于非事务表,如果值出现在单行语句或多行语句的第1行,则放弃该语句。没有 STRICT_TRANS_TABLES,即非严格模式,int类型的字段,使用空字符串,存为 0;
  3. NO_ZERO_IN_DATE
    这个模式影响着日期中的月份和天数是否可以为 0(注意年份是非 0 的),这个模式也取决于严格模式是否被启用。如果这个模式未启用,那么日期中的零部分被允许并且插入没有警告。如果这个模式启用,那么日期中的零部分插入被作为 0000-00-00并且产生一个警告 。
    这个模式需要注意下,如果启用的话,需要 STRICT_TRANS_TABLES 和 NO_ZERO_IN_DATE 同时启用,否则不起作用,也就是
  4. ERROR_FOR_DIVISION_BY_ZERO
    如果这个模式未启用,那么零除操作将会插入空值并且不会产生警告;如果这个模式启用,零除操作插入空值并产生警告;如果这个模式和严格模式都启用,零除从操作将会产生一个错误。
  5. NO_AUTO_CREATE_USER
    禁止使用 grant 语句自动创建用户,除非认证信息被指定。
  6. NO_ENGINE_SUBSTITUTION
    此模式指定当执行 create 语句或者 alter 语句指定的存储引擎没有启用或者没有编译时,控制默认存储引擎的自动切换。默认是启用状态的。

sql_mode 三种作用域

分别是:会话级别、全局级别、配置(永久生效)级别。
无论设置全局,还是session的变量sql_mode,重启mysql后都会失效;


http://www.ppmy.cn/news/507314.html

相关文章

hdu 6165

题解&#xff1a;先找出所有的强连通分量&#xff0c;再判断各分量能否满足要求(方法&#xff1a;不断地除去入度为0的分量&#xff0c;若出现两个入度为0的分量则不合法) #include<iostream> #include<stdio.h> #include<vector> #include<stack> #in…

code 6101 和 code 6111的解决办法

<<<< code 6101 和 code 6111的解决办法 <<<< <<<< kdbchk: row locked by non-existent transaction <<<< table0 slot0 <<<< lockid2 ktbbhitc2 <<<< Block 96081 failed with…

IEC61850 总结

1. 抽象层次 自己理解&#xff0c;这个是61850的精华所在。在文档中多次提到“面向对象”的概念&#xff0c;在61850的配置文件xml文件中也可以看到对象的概念&#xff0c;可以清楚的看出所抽象出来的对象的之间的关系。 一个SCL文件&#xff0c;最顶层有三个节点&#xff0c;C…

LibreOJ - 6165 欧拉筛法+最小质因子

题目&#xff1a;一天&#xff0c;szb 在上学的路上遇到了灰太狼。 灰太狼&#xff1a;帮我们做出这道题就放了你。 szb&#xff1a;什么题&#xff1f; 灰太狼&#xff1a;求一个能被 [1,n] 内所有数整除的最小数字&#xff0c;并对 100000007 取模。 szb&#xff1a;这题太水…

hdu6165

题目链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid6165 题意&#xff1a;一张有向图&#xff0c;n个点&#xff0c;m条边&#xff0c;保证没有重边和自环。询问任意两个点能否满足任何一方能够到达另外一方。 思路&#xff1a;枚举每个点&#xff0c;预处理搜…

ActiveMQ配置wss

最近把前端页面由原来的http升级为了https&#xff0c;发现之前ActiveMQ提供的ws不能强求了&#xff0c;https服务下要求升级到wss。全网搜索了下&#xff0c;没有找到一个靠谱的文档 一、 证书准备 使用wss连接服务必须使用域名端口&#xff0c;而不能使用ip端口&#xff0c;这…

Libreoj #6165. 一道水题 (快速线性筛素数)

题意&#xff1a;求出能整除[1,n]中所有数的最小整数&#xff0c;对100000007取模。&#xff08;注意是1e87&#xff01;&#xff01;&#xff01;&#xff09; 思路&#xff1a;首先用线性筛筛出[1,n]的所有素数&#xff0c;记为p[i]。答案是对每个p[i]&#xff0c;求出最大的…

ESP32 Wi-Fi、BLE 等示例的固件大小及优化 相关组件大小对比

一. 测试目的 经常会有开发者提出基于 ESP32 Wi-Fi、BLE 等示例的固件大小及优化 & 相关组件大小对比&#xff0c;本文将测试针对相关示例进行修改测试。 二. 测试环境 为了保证测试结果的一致性&#xff0c;采用以下测试环境: esp-idf 编写本文时&#xff0c;使用的 esp…