Mysql無(wú)法選取非聚合列的解決方法
1. 前言
最近升級(jí)博客,給文章頁(yè)面底部增加了兩個(gè)按鈕,可以直接跳轉(zhuǎn)到上一篇和下一篇。
如下圖所示:
實(shí)現(xiàn)這個(gè)功能的難點(diǎn)在于:數(shù)據(jù)庫(kù)怎么選取出一條記錄的前后兩條相鄰的記錄?
2. 數(shù)據(jù)庫(kù)設(shè)計(jì)
關(guān)于我文章數(shù)據(jù)庫(kù)的設(shè)計(jì)如下圖所示:
可以看到,每條記錄的身份是索引Id。因?yàn)橹坝泻芏辔恼掠涗洷粍h除了,所以,Id并不是連續(xù)的。
如果當(dāng)前文章的索引值是33,那么可以通過(guò)以下命令來(lái)得到前后相鄰的 2 篇文章:
select * from passage where id in (select case when SIGN(id - 32 )>0 THEN MIN(id) when SIGN(id - 32 )<0 THEN MAX(id) end from passage where id != 34 GROUP BY SIGN(id- 32 ) ORDER BY SIGN(id- 32 ) ) ORDER BY id;
3. 無(wú)法選取聚合列
在執(zhí)行上面命令時(shí),Mysql給了我個(gè): SELECT list is not in GROUP BY clause ...
的報(bào)錯(cuò)。經(jīng)過(guò) Google 得知,mysql 5.7以上,默認(rèn)啟動(dòng)了only_full_group_by
,MySQL 就會(huì)拒絕選擇列表、條件或順序列表引用的查詢(xún)。
以下是原文:
Reject queries for which the select list, HAVING condition, or ORDER BY list refer to nonaggregated columns that are neither named in the GROUP BY clause nor are functionally dependent on (uniquely determined by) GROUP BY columns. As of MySQL 5.7.5, the default SQL mode includes ONLY_FULL_GROUP_BY. (Before 5.7.5, MySQL does not detect functional dependency and ONLY_FULL_GROUP_BY is not enabled by default. For a description of pre-5.7.5 behavior, see the MySQL 5.6 Reference Manual.)
所以,我們應(yīng)該設(shè)置sql_mode中不包含only_full_group_by
選項(xiàng)。MySQL 5.7.5后only_full_group_by成為sql_mode的默認(rèn)選項(xiàng)之一,這可能導(dǎo)致一些sql語(yǔ)句失效。
進(jìn)入 mysql 配置文件,在[mysqld]部分中添加以下配置,并且重啟 mysql 即可。
[mysqld] # ... other config sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATEERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION # delete 'only_full_group_by' # ... other config
運(yùn)行本文第二部分的 mysql 的命令,結(jié)果如下圖所示:
4. 相關(guān)鏈接
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- MySQL中聚合函數(shù)count的使用和性能優(yōu)化技巧
- MySQL常用聚合函數(shù)詳解
- MySql 中聚合函數(shù)增加條件表達(dá)式的方法
- php+mysql開(kāi)源XNA 聚合程序發(fā)布 下載
- MySQL單表查詢(xún)操作實(shí)例詳解【語(yǔ)法、約束、分組、聚合、過(guò)濾、排序等】
- MySQL查詢(xún)排序與查詢(xún)聚合函數(shù)用法分析
- MySQL使用聚合函數(shù)進(jìn)行單表查詢(xún)
- MySQL 分組查詢(xún)和聚合函數(shù)
- mysql連續(xù)聚合原理與用法實(shí)例分析
- mysql聚合統(tǒng)計(jì)數(shù)據(jù)查詢(xún)緩慢的優(yōu)化方法
相關(guān)文章
MySQL初學(xué)者可以告別分組聚合查詢(xún)的困擾了
這篇文章主要為大家介紹了MySQL分組聚合查詢(xún)的難點(diǎn)講解,幫助MySQL初學(xué)著告別分組聚合查詢(xún)的困擾,有需要的朋友可以借鑒參考下,希望能夠有所進(jìn)步2021-10-10mysql指定某行或者某列的排序?qū)崿F(xiàn)方法
這篇文章主要介紹了mysql指定某行或者某列的排序,需要的朋友可以參考下2017-05-05Mysql查詢(xún)時(shí)如何使用for update行鎖還是表鎖
這篇文章主要介紹了Mysql查詢(xún)時(shí)如何使用for update行鎖還是表鎖問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08