欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL報(bào)錯(cuò)Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre

 更新時(shí)間:2024年09月04日 09:13:49   作者:lucky多多  
這篇文章主要介紹了MySQL報(bào)錯(cuò)Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggre問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

解決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)文章

最新評(píng)論