mysql5.7版本中,如果DISTINCT和order by一起使用将会报3065错误

本文讲述了在MySQL5.7中,DISTINCT和ORDERBY结合使用可能导致3065错误的问题,解决方法是在my.cnf或my.ini中设置sql_mode为更严格的模式,并提供了一个示例SQL。

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

#mysql5.7版本中,如果DISTINCT和order by一起使用将会报3065错误,sql语句

无法执行。这是由于5.7版本语法比之前版本语法要求更加严格导致的。
#推荐在mysql的配置文件my.cnf文件(linux)/my.ini文件(window) 的mysqld中增加或者修改sql_model配置选项
#sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
#重启后生效
SELECT DISTINCT
    CONCAT('SELECT ',rowlist

,' FROM ',db,'.',tb,
    ' ORDER BY ',rowlist,';') selectSql
    FROM
    (
        SELECT
            engine,table_schema db,table_name tb,
            index_name,GROUP_CONCAT(column_name ORDER BY seq_in_index) rowlist
        FROM
        (
            SELECT
                B.engine,A.table_schema

,A.table_name,
                A.index_name,A.column_name,A.seq_in_index
            FROM
                information_schema.statistics A INNE

R JOIN
                (
                    SELECT engine,table_schema,table_name
                    FROM information_schema.tables WHERE
                    engine='InnoDB'
                ) B USING (table_schema,table_name)
            WHERE B.table_schema NOT IN ('information_schema','mysql')
            ORDER BY table_schema,table_name,index_name,seq_in_index
        ) A
        GROUP BY table_schema,table_name,index_name
    ) AA
ORDER BY db,tb;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值