MySQL 5.7升級8.0報異常:ONLY_FULL_GROUP_BY的問題解決
異常
MySQL8.0默認的SQL模式包含了ONLY_FULL_GROUP_BY,MySQL5.7默認的SQL模式也包含了ONLY_FULL_GROUP_BY,但是MySQL5.6是不包含的,有的項目從5.6升級到5.7的時候,把SQL模式中的ONLY_FULL_GROUP_BY去掉了,再升級到8.0時,可能會報下面的異常:
Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'java_test.student.subject' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
ONLY_FULL_GROUP_BY
ONLY_FULL_GROUP_BY是MySQL的一個SQL模式,它要求在使用GROUP BY語句時,SELECT列表、HAVING條件或ORDER BY列表中的每個列,要么是聚合函數的一部分(如COUNT(), SUM(), AVG()等),要么必須在GROUP BY子句中明確指定。這一模式的設計初衷是增強查詢的準確性和可預測性,避免因為列的不明確引用而導致的數據錯誤或不一致。
異常解決
假設我們有一張student表,包含name(姓名)、subject(科目)、score(分數)三個字段,在ONLY_FULL_GROUP_BY啟用時,我們嘗試運行如下查詢,就會報上面的異常:
select name, subject, score from student group by name
解決方法有兩個:
1、修改sql
使用聚合函數處理非GROUP BY列,或將其加入到GROUP BY子句中,常見的聚合函數包括SUM(求和)、AVG(平均值)、MAX(最大值)、MIN(最小值)、COUNT(計數)等。
select name, subject, sum(score) from student group by name, subject
2、修改sql_mode
1)修改當前會話的sql_mode
查看當前會話的sql_mode:
select @@sql_mode; 或者 select @@session.sql_mode;
修改當前會話的sql_mode:
SET sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY','')); 或者 SET session sql_mode=(SELECT REPLACE(@@session.sql_mode,'ONLY_FULL_GROUP_BY',''));
2)修改全局配置的sql_mode
查看全局配置的sql_mode:
select @@global.sql_mode;
修改全局配置的sql_mode:
SET global sql_mode=(SELECT REPLACE(@@global.sql_mode,'ONLY_FULL_GROUP_BY',''));
3)永久修改sql_mode
若想永久修改sql_mode,需要修改MySQL配置文件(my.cnf或my.ini)
A、打開MySQL配置文件,具體路徑根據安裝方式和操作系統(tǒng)不同,通常位于:
Linux: /etc/my.cnf 或 /etc/mysql/my.cnf
Windows: C:\ProgramData\MySQL\MySQL Server X.Y\my.ini
使用文本編輯器打開文件
B、找到[mysqld]部分,添加或修改如下行:
[mysqld] sql_mode=新模式
將新模式替換為你希望設置的值
MySQL配置文件的修改,重啟MySQL服務后才能生效。
注:
1)建議寫sql時盡量規(guī)范,在使用GROUP BY語句時,SELECT列表、HAVING條件或ORDER BY列表中的每個列,要么是聚合函數的一部分(如COUNT(), SUM(), AVG()等),要么必須在GROUP BY子句中明確指定。
2)當我們需要修改sql_mode時,一般情況下,先修改全局配置,再修改配置文件,這樣修改后,即使MySQL服務重啟后sql_mode也是最新的。
到此這篇關于MySQL 5.7升級8.0報異常:ONLY_FULL_GROUP_BY的問題解決的文章就介紹到這了,更多相關MySQL 5.7升級8.0報異常內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
一次docker登錄mysql報錯問題的實戰(zhàn)記錄
這篇文章主要給大家介紹了一次docker登錄mysql報錯問題的實戰(zhàn)記錄,文中通過實例代碼介紹的非常詳細,對大家學習或者使用docker具有一定的參考學習價值,需要的朋友可以參考下2022-01-01MySQL中的case?when中對于NULL值判斷的坑及解決
這篇文章主要介紹了MySQL中的case?when中對于NULL值判斷的坑及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12從MySQL的源碼剖析Innodb buffer的命中率計算
這篇文章主要介紹了從MySQL的源碼剖析Innodb buffer的命中率計算,作者結合C語言寫的算法來分析innodb buffer hit Ratios,需要的朋友可以參考下2015-05-05