国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

怎么優(yōu)化mysql分頁(yè)時(shí)offset過(guò)大的Sql

發(fā)布時(shí)間:2021-09-27 17:43 來(lái)源:億速云 閱讀:0 作者:小新 欄目: Mysql 歡迎投稿:712375056

這篇文章將為大家詳細講解有關(guān)怎么優(yōu)化分頁(yè)時(shí)offset過(guò)大的Sql,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

通常分頁(yè)查詢(xún)的時(shí)候會(huì )使用這樣的語(yǔ)句:

SELECT
*
FROM table
where condition1 = 0
and condition2 = 0
and condition3 = -1
and condition4 = -1
order by id asc
LIMIT 2000 OFFSET 50000

當offset特別大時(shí),這條語(yǔ)句的執行效率會(huì )明顯減低,而且效率是隨著(zhù)offset的增大而降低的。

原因為:

MySQL并不是跳過(guò)offset行,而是取offset+N行,然后返回放棄前offset行,返回N行,當offset特別大,然后單條數據也很大的時(shí)候,每次查詢(xún)需要獲取的數據就越多,自然就會(huì )很慢。

優(yōu)化方案:

SELECT
*
FROM table
JOIN
(select id from table
where condition1 = 0
and condition2 = 0
and condition3 = -1
and condition4 = -1
order by id asc
LIMIT 2000 OFFSET 50000)
as tmp using(id)

或者

SELECT a.* FROM table a, 
(select id from table
where condition1 = 0
and condition2 = 0
and condition3 = -1
and condition4 = -1
order by id asc
LIMIT 2000 OFFSET 50000) b 
where a.id = b.id

先獲取主鍵列表,再通過(guò)主鍵查詢(xún)目標數據,即使offset很大,也是獲取了很多的主鍵,而不是所有的字段數據,相對而言效率會(huì )提升很多。

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。

免费精品国产自产拍在线观看图片| 欧亚精品一区三区免费| 国内精品久久久久久久久齐齐| 无人区码一码二码三MBA智库| 亚洲国产成人无码精品| 亚洲线精品一区二区三区四区|