1. 程式人生 > 實用技巧 >window下 mysql5.7查詢報錯: ORDER BY clause is not in GROUP BY..this is incompatible with sql_mode=only_full_group_by

window下 mysql5.7查詢報錯: ORDER BY clause is not in GROUP BY..this is incompatible with sql_mode=only_full_group_by

一、舊方法,修改mysql配置檔案,但是會導致資料丟失等不可預知的錯誤

在用mysql執行如下查詢的時候:

select * from `sys_user_group` group by `GROUP_ID`

報錯資訊如下:

[Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated column 'information_schema.PROFILING.SEQ' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

錯誤的原因是我mysql版本是5.7的,使用如下語句查詢可知

select @@sql_mode;

裡面預設設定了

sql_mode=only_full_group_by

only_full_group_by:使用這個就是使用和oracle一樣的group 規則, select的列都要在group中,或者本身是聚合列(SUM,AVG,MAX,MIN) 才行,其實這個配置目前個人感覺和distinct差不多的,所以去掉就好

直接修改mysql配置檔案(我的系統是Ubuntu16.04的,在/etc/mysql/mysql.conf.d/mysqld.cnf中並沒有sql_mode這個配置,所以直接加上就好,如果是其他系統有得修改就不用添加了)

[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配置檔案的完整配置如下:

[mysqld_safe]
socket          = /var/run/mysqld/mysqld.sock
nice            = 0

[mysqld]
#
# * Basic Settings
#
user            = mysql
pid-file        = /var/run/mysqld/mysqld.pid
socket          = /var/run/mysqld/mysqld.sock
port            = 3306
basedir         = /usr
datadir         = /var/lib/mysql
tmpdir          = /tmp
lc-messages-dir = /usr/share/mysql
skip-external-locking
lower_case_table_names=1
character-set-server=utf8
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
#
# Instead of skip-networking the default is now to listen only on
# localhost which is more compatible and is not less secure.
#bind-address           = 127.0.0.1
#
# * Fine Tuning
#
key_buffer_size         = 16M
max_allowed_packet      = 16M
thread_stack            = 192K

二、不修改配置檔案,修改sql寫法

在分組時,5.7之前我們會這樣寫:

SELECT `id` AS `id`,`name` FROM `game` GROUP BY `name`

但是在5.7中,需要使用聚合函式:

SELECT ANY_VALUE(`id`) AS `id`,MAX(`id`),`name` FROM `game` GROUP BY `name`

三、sql_mode解析:

參考自:https://blog.csdn.net/Cooldiok/article/details/59131952

ONLY_FULL_GROUP_BY: 對於GROUP BY聚合操作,如果在SELECT中的列,沒有在GROUP
BY中出現,那麼這個SQL是不合法的,因為列不在GROUP BY從句中

NO_AUTO_VALUE_ON_ZERO: 該值影響自增長列的插入。預設設定下,插入0或NULL代表生成下一個自增長值。如果使用者
希望插入的值為0,而該列又是自增長的,那麼這個選項就有用了。

STRICT_TRANS_TABLES: 在該模式下,如果一個值不能插入到一個事務表中,則中斷當前的操作,對非事務表不做限制
NO_ZERO_IN_DATE: 在嚴格模式下,不允許日期和月份為零

NO_ZERO_DATE: 設定該值,mysql資料庫不允許插入零日期,插入零日期會丟擲錯誤而不是警告。

ERROR_FOR_DIVISION_BY_ZERO: 在INSERT或UPDATE過程中,如果資料被零除,則產生錯誤而非警告。如
果未給出該模式,那麼資料被零除時MySQL返回NULL

NO_AUTO_CREATE_USER: 禁止GRANT建立密碼為空的使用者

NO_ENGINE_SUBSTITUTION:
如果需要的儲存引擎被禁用或未編譯,那麼丟擲錯誤。不設定此值時,用預設的儲存引擎替代,並丟擲一個異常

PIPES_AS_CONCAT:
將”||”視為字串的連線操作符而非或運算子,這和Oracle資料庫是一樣的,也和字串的拼接函式Concat相類似

ANSI_QUOTES: 啟用ANSI_QUOTES後,不能用雙引號來引用字串,因為它被解釋為識別符
————————————————

轉載 :https://blog.csdn.net/u014520745/article/details/76056170