MySQL報(bào)錯(cuò)Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre
解決MySQL5.7版本之后使用GROUP BY語(yǔ)句時(shí)報(bào)錯(cuò)
今天使用mysql簡(jiǎn)單的一句分組查詢語(yǔ)句(GROUP BY)報(bào)錯(cuò)了。
mysql> SELECT * FROM tb GROUP BY empid;
ERROR 1055 (42000): Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'db1.tb.sales' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
查了問(wèn)題原因和解決方法,成功解決。
問(wèn)題原因
原因:
- 使用GROUP BY 語(yǔ)句違背了sql_mode=only_full_group_by。
- 因?yàn)閙ysql版本5.7之后默認(rèn)的模式是ONLY_FULL_GROUP_BY。
官網(wǎng)文檔的原話:
說(shuō)人話,大概意思就是說(shuō)(使用google翻譯):
拒絕選擇列表、HAVING 條件或 ORDER BY 列表引用非聚合列的查詢,這些列既不在 GROUP BY 子句中命名,也不在功能上依賴于(唯一確定的)GROUP BY 列。
從 MySQL 5.7.5 開(kāi)始,默認(rèn) SQL 模式包括 ONLY_FULL_GROUP_BY。(在 5.7.5 之前,MySQL 不檢測(cè)函數(shù)依賴,并且默認(rèn)不啟用 ONLY_FULL_GROUP_BY。有關(guān) 5.7.5 之前的行為的描述,請(qǐng)參閱 MySQL 5.6 參考手冊(cè)。)
標(biāo)準(zhǔn) SQL 的 MySQL 擴(kuò)展允許在 HAVING 子句中引用選擇列表中的別名表達(dá)式。 在 MySQL 5.7.5 之前,啟用 ONLY_FULL_GROUP_BY 會(huì)禁用此擴(kuò)展,因此需要使用非別名表達(dá)式編寫 HAVING 子句。 從 MySQL 5.7.5 開(kāi)始,此限制被取消,因此 HAVING 子句可以引用別名,無(wú)論是否啟用了 ONLY_FULL_GROUP_BY。
解決方法
1、先使用SQL查詢sql_mode
select @@global.sql_mode
2、重新設(shè)置sql_mode,刪除ONLY_FULL_GROUP_BY
set @@global.sql_mode ='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'
3、退出重進(jìn)
# 退出 quit # 再次登錄(命令行模式) mysql -u root -p
再次執(zhí)行查詢語(yǔ)句,
SELECT * FROM tb GROUP BY empid;
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Ubuntu下啟動(dòng)、停止、重啟MySQL,查看錯(cuò)誤日志命令大全
這篇文章主要介紹了Ubuntu下啟動(dòng)、停止、重啟MySQL,查看錯(cuò)誤日志命令大全,需要的朋友可以參考下2014-06-06MySQL與存儲(chǔ)過(guò)程的相關(guān)資料
這篇文章主要介紹了MySQL與存儲(chǔ)過(guò)程的相關(guān)資料,需要的朋友可以參考下2007-03-03MySQL數(shù)據(jù)權(quán)限的實(shí)現(xiàn)詳情
這篇文章主要介紹了MySQL數(shù)據(jù)權(quán)限的實(shí)現(xiàn)詳情,文章通過(guò)實(shí)際案例,從代碼實(shí)戰(zhàn)的角度來(lái)實(shí)現(xiàn)這樣的一個(gè)數(shù)據(jù)權(quán)限。具體詳細(xì)介紹,具有一定的參考價(jià)值2022-08-08mysql中key 、primary key 、unique key 與index區(qū)別
這篇文章主要介紹了mysql中key 、primary key 、unique key 與index區(qū)別的相關(guān)資料,需要的朋友可以參考下2016-10-10Centos 6.4源碼安裝mysql-5.6.28.tar.gz教程
這篇文章主要為大家詳細(xì)介紹了Centos 6.4源碼安裝mysql-5.6.28.tar.gz教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01Mysql TIMESTAMPDIFF函數(shù)示例詳解
這篇文章主要介紹了Mysql TIMESTAMPDIFF函數(shù)示例詳解,TIMESTAMPDIFF函數(shù)返回datetime_expr2 - datetime_expr1的結(jié)果,其中datetime_expr1和datetime_expr2可以是DATE或DATETIME類型值,本文給大家詳細(xì)講解,需要的朋友可以參考下2023-03-03Ubuntu10下如何搭建MySQL Proxy讀寫分離探討
MySQL Proxy是一個(gè)處于你的Client端和MySQL server端之間的簡(jiǎn)單程序,它可以監(jiān)測(cè)、分析或改變它們的通信2012-11-11