mysql解决1055-Expression#22ofSELECT list is not in GROUP BY clause and contains nonaggregated column ‘
生活随笔
收集整理的這篇文章主要介紹了
mysql解决1055-Expression#22ofSELECT list is not in GROUP BY clause and contains nonaggregated column ‘
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
問題:
在mysql5.7以上的版本中,對于 group by 的這種聚合操作,如果在select 中的列,沒有在group by 中出現,那么這個SQL是不合法的,因為列不在group by的從句中,所以對于設置了這個mode的數據庫,only_full_group_by:使用這個就是使用和oracle一樣的group 規則, select的列都要在group中,或者本身是聚合列(SUM,AVG,MAX,MIN) 才行。
使用 SQL 語句可以查詢這個配置
解決方案:
方案1.運行sql,每次重啟電腦后都需要重寫運行
方案2.如果是Linux,就在配置文件(my.cnf)中修改 sql_mode 的配置(在/usr/local/etc/my.cnf路徑下)。如果是Windows,就修改配置文件my.ini文件,添加如下:
sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';重啟mysql:
service mysqld restart總結
以上是生活随笔為你收集整理的mysql解决1055-Expression#22ofSELECT list is not in GROUP BY clause and contains nonaggregated column ‘的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微博国际版能干嘛(新浪博客的微博)
- 下一篇: linux cmake编译源码,linu