解决mysql5.7 DISTINCT和order by 导致3065错误

本文介绍MySQL 5.7中使用DISTINCT与ORDER BY时出现的3065错误,并提供两种解决方案:一是通过PHP进行排序;二是修改MySQL配置文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 在新版的mysql5.7的版本中,如果DISTINCTorder by一起使用将会报3065错误,sql语句无法执行。最新的mysql5.7版本语法比之前5.6版本语法更加严格导致的。DISTINCT和order by都会对数据进行排序操作,所以会产生冲突。

    解决方法一:

        在sql语句中使用DISTINCT时不使用order by进行排序,获取结果集后通过php进行数据的排序,同事也提高的mysql的性能。同时group by,limit和其中的一起搭配使用也会导致错误。

    解决方法二:

        编辑mysql5.7的配置文件,添加配置 sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,这段代码同时也可以解决mysql5.7中的group by导致的1055错误

bash
  1. vim /etc/my.cnf
  2. #添加下面的配置
  3. sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

    重启mysql生效

bash
  1. service mysqld restart

mysql5.7 3065错误解决.png

转载自http://zixuephp.net/article-322.html

### 正确使用 MySQL 中的 DISTINCT ORDER 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 子句之中;只有当此途径不可行的情况下才考虑其他的替代方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值