window下 mysql5.7查詢報錯: ORDER BY clause is not in GROUP BY..this is incompatible with sql_mode=only_full_group_by
阿新 • • 發佈:2020-07-22
一、舊方法,修改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