1. 程式人生 > 資料庫 >mysql不支援group by的解決方法小結

mysql不支援group by的解決方法小結

下載安裝的是最新版的mysql5.7.x版本,預設是開啟了 only_full_group_by 模式的,但開啟這個模式後,原先的 group by 語句就報錯,然後又把它移除了。

一旦開啟 only_full_group_by ,感覺,group by 將變成和 distinct 一樣,只能獲取受到其影響的欄位資訊,無法和其他未受其影響的欄位共存,這樣,group by 的功能將變得十分狹窄了

only_full_group_by 模式開啟比較好。

因為在 mysql 中有一個函式: any_value(field) 允許,非分組欄位的出現(和關閉 only_full_group_by 模式有相同效果)。

具體出錯提示:

[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

1.1. 1、檢視sql_mode

select @@global.sql_mode;

1.2. 查詢出來的值為:

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

2、去掉ONLY_FULL_GROUP_BY,重新設定值。

select @@global.sql_mode;

set sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';
set global sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';

2.1. 3、上面是改變了全域性sql_mode,對於新建的資料庫有效。對於已存在的資料庫,則需要在對應的資料下執行:

set sql_mode ='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';  

解決辦法大致有兩種:

一:在sql查詢語句中不需要group by的欄位上使用any_value()函式
這種對於已經開發了不少功能的專案不太合適,畢竟要把原來的sql都給修改一遍

3.1.

二:修改my.cnf(windows下是my.ini)配置檔案,刪掉only_full_group_by這一項
若我們專案的mysql安裝在ubuntu上面,找到這個檔案開啟一看,裡面並沒有sql_mode這一配置項,想刪都沒得刪。

當然,還有別的辦法,開啟mysql命令列,執行命令

select @@sql_mode;
這樣就可以查出sql_mode的值,複製這個值,在my.cnf中新增配置項(把查詢到的值刪掉only_full_group_by這個選項,其他的都複製過去):

sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION;
如果 [mysqld] 這行被註釋掉的話記得要開啟註釋。然後重重啟mysql服務

注:使用命令

set sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

這樣可以修改一個會話中的配置項,在其他會話中是不生效的。 

如果上面的不夠清楚可以參考下面的語句

進入mysql命令列 執行如下兩句語句

set global sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';
set session sql_mode='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';

但是當重啟mysql 問題又會復現

找到my.cnf,編輯它~把以下命令放到合適位置,重啟mysql 服務,OK~報錯沒啦~

[mysqld]
sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

注意 sql_model那句話 一定要放在[mysqld] 內容區域

mysql5.7不支援group by的解決辦法

1、檢視sql_mode

select @@global.sql_mode

查詢出來的值為:

ONLY_FULL_GROUP_BY,NO_ENGINE_SUBSTITUTION

2、去掉ONLY_FULL_GROUP_BY,重新設定值。

set @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';

linux 下mysql5.7+使用group by、order by報錯ONLY_FULL_GROUP_BY不修改配置檔案

1.進入mysql
2.查詢出sql_mode:

SELECT @@GLOBAL.sql_mode;
SELECT @@SESSION.sql_mode;
SELECT @@sql_mode;

mysql不支援group by的解決方法小結

發現前面都有ONLY_FULL_GROUP_BY

3. 在命令列中輸入
set @@GLOBAL.sql_mode=(select replace(@@GLOBAL.sql_mode,‘ONLY_FULL_GROUP_BY',''));
以上三個sql_home都設定一遍,

mysql不支援group by的解決方法小結

4.退出mysql重新進入檢視sql_mode;

mysql不支援group by的解決方法小結

到這裡基本上就差不多了。