当前位置: 首页 > news >正文

mysql which is not in SELECT list; this is incompatible with DISTINCT解决方案

mysql报错Expression #1 of ORDER BY clause is not in SELECT list, references column ‘xxx’ which is not in SELECT list; this is incompatible with DISTINCT解决方案:

这是在 mysql5.7 版本,DISTINCT 与 order by 在一起用时则会报3065错误。因为mysql5.7的语法比 mysql5.6 的语法更严格,将DISTINCT 与 order by 一起用时这两个都会进行排序处理。

查看sql_mode:

select @@sql_mode

如果查询结果发现有ONLY_FULL_GROUP_BY 代表是开启严格模式,按照文档走就行

临时解决方案:

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

长期解决方案:/etc/my.cnf增加如下配置

vim /etc/my.cnf
#在my.cnf新增如下配置后重启mysql服务
sql_mode="STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION"

另:mysql 的 mode 常用的有以下几种:

  1. ONLY_FULL_GROUP_BY:出现在select语句、HAVING条件和ORDER BY语句中的列,必须是GROUP BY的列或者依赖于GROUP BY列的函数列。
  2. NO_AUTO_VALUE_ON_ZERO:该值影响自增长列的插入。默认设置下,插入0或NULL代表生成下一个自增长值。如果用户希望插入的值为0,而该列又是自增长的,那么这个选项就有用了。
  3. STRICT_TRANS_TABLES:在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
  4. NO_ZERO_IN_DATE:这个模式影响了是否允许日期中的月份和日包含0。如果开启此模式,2016-01-00是不允许的,但是0000-02-01是允许的。它实际的行为受到 strict mode是否开启的影响1。
  5. NO_ZERO_DATE:设置该值,mysql数据库不允许插入零日期。它实际的行为受到 strict mode是否开启的影响2。
  6. ERROR_FOR_DIVISION_BY_ZERO:在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。如
    果未给出该模式,那么数据被零除时MySQL返回NULL
  7. NO_AUTO_CREATE_USER:禁止GRANT创建密码为空的用户
  8. NO_ENGINE_SUBSTITUTION:如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
  9. PIPES_AS_CONCAT:将”||”视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似
  10. ANSI_QUOTES:启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符

相关文章:

  • Windows系统搭建Appium 2 和 Appium Inspector 环境
  • SpringBoot JprotoBuf序列化与反序列化的实现
  • unity学习笔记18
  • docker-compose脚本编写及常用命令
  • 【JavaScript】3.2 JavaScript性能优化
  • 【Azure 架构师学习笔记】- Azure Databricks (1) - 环境搭建
  • 011 OpenCV warpAffine
  • 如何在vs2017及以前版本(vs2010、vs2015)上添加 添加类型库中的MFC类
  • MySQL的安装步骤教程以及基本操作--详细讲解
  • 全微分方程@曲线积分的基本定理(公式)
  • 做一件荒谬的事:用AI推理下一次双色球结果 v0.1
  • Echarts大屏可视化_04 横向柱状图模块的引入和开发
  • 修改element的抽屉<el-drawer的宽度
  • 数据库管理-第120期 初探Halo数据库(202301201)
  • react native 环境准备
  • ➹使用webpack配置多页面应用(MPA)
  • git 常用命令
  • gops —— Go 程序诊断分析工具
  • PHP 使用 Swoole - TaskWorker 实现异步操作 Mysql
  • Protobuf3语言指南
  • 当SetTimeout遇到了字符串
  • ------- 计算机网络基础
  • 简单实现一个textarea自适应高度
  • 浅析微信支付:申请退款、退款回调接口、查询退款
  • 如何设计一个微型分布式架构?
  • 数据结构java版之冒泡排序及优化
  • 掌握面试——弹出框的实现(一道题中包含布局/js设计模式)
  • 最简单的无缝轮播
  • 交换综合实验一
  • # 20155222 2016-2017-2 《Java程序设计》第5周学习总结
  • # Swust 12th acm 邀请赛# [ A ] A+B problem [题解]
  • (4)事件处理——(7)简单事件(Simple events)
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第5节(封闭类和Final方法)
  • (附源码)spring boot球鞋文化交流论坛 毕业设计 141436
  • (附源码)springboot学生选课系统 毕业设计 612555
  • (简单) HDU 2612 Find a way,BFS。
  • (力扣记录)1448. 统计二叉树中好节点的数目
  • (论文阅读26/100)Weakly-supervised learning with convolutional neural networks
  • (五)网络优化与超参数选择--九五小庞
  • (学习日记)2024.01.09
  • (一)pytest自动化测试框架之生成测试报告(mac系统)
  • (一)SpringBoot3---尚硅谷总结
  • (转)iOS字体
  • (轉貼) 2008 Altera 亞洲創新大賽 台灣學生成果傲視全球 [照片花絮] (SOC) (News)
  • .NET CF命令行调试器MDbg入门(三) 进程控制
  • .net mvc部分视图
  • .NET 发展历程
  • .net反编译工具
  • .Net下使用 Geb.Video.FFMPEG 操作视频文件
  • @ComponentScan比较
  • @EnableWebMvc介绍和使用详细demo
  • @FeignClient注解,fallback和fallbackFactory
  • [ vulhub漏洞复现篇 ] JBOSS AS 5.x/6.x反序列化远程代码执行漏洞CVE-2017-12149
  • [《百万宝贝》观后]To be or not to be?
  • [AHOI2009]中国象棋 DP,递推,组合数