您好,登錄后才能下訂單哦!
本文主要給大家介紹MySQL 5.7使用group by語(yǔ)句報(bào)1055錯(cuò)誤處理方法解析,希望可以給大家補(bǔ)充和更新些知識(shí),如有其它問題需要了解的可以持續(xù)在億速云行業(yè)資訊里面關(guān)注我的更新文章的。
1. 在5.7版本以上mysql中使用group by語(yǔ)句進(jìn)行分組時(shí), 如果select的字段 , 不是完全對(duì)應(yīng)的group by后面的字段 , 有其他字段 , 那么就會(huì)報(bào)這個(gè)錯(cuò)誤
ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column
2.這是因?yàn)楦甙姹緈ysql添加了一個(gè)sql_mode
查看sql_mode
select @@sql_mode;
mysql> select @@sql_mode;
+-------------------------------------------------------------------------------------------------------------------------------------------+
| @@sql_mode |
+-------------------------------------------------------------------------------------------------------------------------------------------+
| ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_pISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
+-------------------------------------------------------------------------------------------------------------------------------------------+
可以看到有一個(gè)ONLY_FULL_GROUP_BY , 這個(gè)就是嚴(yán)格控制group by 和select 字段的 , 在不改變sql語(yǔ)句的前提下 , 把這個(gè)去掉就可以了
3.我的ubuntu系統(tǒng)下編輯的這個(gè)文件 /etc/mysql/conf.d/mysql.cnf , 其他系統(tǒng)找到對(duì)應(yīng)的配置文件就可以了 ,在[mysqld]塊下 ,把sql_mode配置上 , 并且去掉ONLY_FULL_GROUP_BY
sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_pISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
4.此時(shí)就正常了
相關(guān)教程:mysql視頻教程
以上就是在MySQL 5.7上使用group by語(yǔ)句出現(xiàn)1055錯(cuò)誤問題的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注億速云其它相關(guān)文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。