業務:查詢一個用戶每天支付總金額;
數據庫表:
sql語句:
select DATE(play_date) as '日期', play_user as '支付用戶', SUM(paly_money) from play_info GROUP BY DATE(play_date);
數據庫報錯:
問題起因:
ONLY_FUll_GROUP_BY的意思是:對於GROUP BY聚合操作,如果在SELECT中的列,沒有在GROUP BY中出現,那么這個SQL是不合法的,因為列不在GROUP BY語句中,也就是說查出來的列必須是GROUP BY之后的字段,或者這個字段出現在聚合函數里面。
這個sql語句在別的數據庫執行不會報錯,解決方案如下:
方案一 修改sql語句:
SELECT DATE(play_date) as '日期', ANY_VALUE(play_user) as '支付用戶', ANY_VALUE(SUM(paly_money)) as '支付總金額' from play_info GROUP BY DATE(play_date);
使用ANY_VAKLUE() 方法;
方案二 修改MySQL配置:
在網上一頓搜索后發現這個錯誤信息和sql_mode中的”only_full_group_by”有關,是Mysql5.7 group by新特性,在5.7版本中only_full_group_by這個模式是默認開啟的;
執行sql語句: SELECT @@GLOBAL.sql_mode;
查看sql_mode:
執行sql語句:
set sql_mode=STRICT_TRANS_TABLES,
NO_ZERO_IN_DATE,
NO_ZERO_DATE,
ERROR_FOR_DIVISION_BY_ZERO,
NO_AUTO_CREATE_USER,
NO_ENGINE_SUBSTITUTION;
就是把ONLY_FULL_GROUP_BY刪除,重新set;然后重啟MySQL服務器;
推薦閱讀: https://blog.csdn.net/qq_34581118/article/details/78228262