您好,登錄后才能下訂單哦!
這篇文章主要介紹“mysql order by limit的坑怎么解決”,在日常操作中,相信很多人在mysql order by limit的坑怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”mysql order by limit的坑怎么解決”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
分頁查詢的時候遇到的坑:
發現的問題: 對單個無索引的字段進行排序后limit .發現當被排序字段有相同值時并且在limit范圍內,取的值并不是正常排序后的值,
也就是說,當排在第N行的數據可取key1、 key2 時 , 排序結果可能是key1,也可能是key2。
排序+ limit 結果 (排序鍵無索引)
按cnt取key_word分別前三結果:
原文:
If multiple rows have identical values in the ORDER BY columns, the server is free to return those rows in any order, and may do so differently depending on the overall execution plan. In other words, the sort order of those rows is nondeterministic with respect to the nonordered columns.
是說如果order by的列有相同的值時, mysql會隨機選取這些行,具體根據執行計劃有所不同。
解決: order by 的列中包含一個索引列
此處增加主鍵id為排序列
到此,關于“mysql order by limit的坑怎么解決”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。