https://blog.csdn.net/weixin_42409107/article/details/100074210
Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'x.xxx' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
原因是:
MySQL 5.7.5及以上實現了對功能依賴的檢測。如果啟用了only_full_group_by SQL模式(在默認情況下是這樣),那么MySQL就會拒絕選擇列表、條件或順序列表引用的查詢,這些查詢將引用組中未命名的非聚合列,而不是在功能上依賴於它們。(在5.7.5之前,MySQL沒有檢測到功能依賴項,only_full_group_by在默認情況下是不啟用的。關於前5.7.5行為的描述,請參閱MySQL 5.6參考手冊。)
執行以下個命令,可以查看 sql_mode 的內容。
mysql> SHOW SESSION VARIABLES;
mysql> SHOW GLOBAL VARIABLES;
可見session和global 的sql_mode的值都為:
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
(如果只有其中一個有此內容的話,下面只需要修改有的那個,親測可行)
解決方式:執行以下sql
set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
set session sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
最后這一步至關重要,好多教程中都沒有寫,上面是能解決問題,但是當你的mysql重啟后,問題就又恢復了。
打開你的my.ini文件在[mysqld] 如果目錄下,不存在看看 my.cnf下面,如果做了掛載則在掛載的配置文件加上:sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
重啟mysql容器
記住 位置一定不能錯!!!要不然不生效