mysql5.7 DISTINCT 后 order by 报错:[3065] 快速解决方案

主要报错信息 mysql 3065 :

### Cause: java.sql.SQLException: Expression #1 of ORDER BY clause is not in SELECT list, references column 'db.SU.ORG_ID' which is not in SELECT list; this is incompatible with DISTINCT
; uncategorized SQLException; SQL state [HY000]; error code [3065]; Expression #1 of ORDER BY clause is not in SELECT list, references column 'db.SU.ORG_ID' which is not in SELECT list; this is incompatible with DISTINCT; nested exception is java.sql.SQLException: Expression #1 of ORDER BY clause is not in SELECT list, references column 'db.SU.ORG_ID' which is not in SELECT list; this is incompatible with DISTINCT
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:89)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
	at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:73)
	at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:446)

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

解决方案:

在 mysql 配置文件中加入:

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

然后重启 mysql 服务既可。

 

另: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后,不能用双引号来引用字符串,因为它被解释为识别符

 

 

 

### 正确使用 MySQL 中的 DISTINCTORDER BYMySQL 5.7 版本中,当 `DISTINCT` 和 `ORDER BY` 同时使用时可能会触发错误 3065 或其他类似的语法错误。这是因为这两个关键字都涉及到了对查询结果集的操作,特别是排序方面的工作机制不同而产生了冲突。 为了确保 SQL 查询能够正常工作并返回预期的结果,可以采取以下几种方式来调整: #### 方法一:仅保留必要的列用于排序 如果确实需要同时应用 `DISTINCT` 来消除重复记录以及通过某些特定字段来进行排序,则应该保证所指定用来排序的那个字段也必须出现在选择列表里。例如对于给定的例子来说,可以通过修改查询语句使得被排序字段同样作为输出的一部分: ```sql SELECT DISTINCT a.title, a.tax_no, a.create_date FROM order_invoice a LEFT JOIN order_data b ON a.order_id = b.order_id WHERE b.user_id = 166 AND a.state = 20 AND a.head_type = 2 ORDER BY a.create_date DESC LIMIT 0, 3; ``` 这样做的好处是可以让 MySQL 明白哪些数据是用来做最终显示用途的,同时也明确了要按照哪个字段进行排序[^4]。 #### 方法二:移除不必要的排序条件 另一种简单的方法就是完全去掉 `ORDER BY` 部分,只保留 `DISTINCT` 关键字以去除冗余的数据条目。不过这通常不是最佳实践,因为很多时候业务逻辑上还是希望能够得到有序的结果集合。 #### 方法三:更改服务器配置选项 还可以考虑改变 MySQL 的全局设置,即编辑 my.cnf 文件并将 sql-mode 设置为空字符串 (`sql-mode=""`) 或者适当放宽一些模式规则如添加 `NO_ENGINE_SUBSTITUTION, STRICT_TRANS_TABLES` 到现有的 sql_mode 值当中去。但是需要注意的是这样做可能会影响到整个数据库实例的安全性和一致性保障措施[^1]。 综上所述,在实际开发过程中推荐优先尝试第一种方法——确保所有参与排序运算的属性都被显式地包含进了 SELECT 子句之中;只有当此途径不可行的情况下才考虑其他的替代方案。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员老油条

您的鼓励将是我创作的大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值