數(shù)據(jù)庫(kù)的優(yōu)化都有哪些方法 為什么MySQL在數(shù)據(jù)庫(kù)較大的時(shí)候分頁(yè)查詢很慢,如何優(yōu)化?
為什么MySQL在數(shù)據(jù)庫(kù)較大的時(shí)候分頁(yè)查詢很慢,如何優(yōu)化?正如房東所說(shuō),分頁(yè)查詢?cè)谖覀兊膶?shí)際應(yīng)用中非常常見,也是問題最多的查詢場(chǎng)景。例如,對(duì)于下面的簡(jiǎn)單語(yǔ)句,通常的思考方式是在name、age、reg
為什么MySQL在數(shù)據(jù)庫(kù)較大的時(shí)候分頁(yè)查詢很慢,如何優(yōu)化?
正如房東所說(shuō),分頁(yè)查詢?cè)谖覀兊膶?shí)際應(yīng)用中非常常見,也是問題最多的查詢場(chǎng)景。例如,對(duì)于下面的簡(jiǎn)單語(yǔ)句,通常的思考方式是在name、age、register中u在time字段上創(chuàng)建一個(gè)復(fù)合索引。這樣,條件排序可以有效地利用索引,性能得到快速提高。
在這種情況下,我們發(fā)現(xiàn)“l(fā)imit”子句變得非常慢。
通常,在分頁(yè)查詢時(shí),可以在上一頁(yè)中獲取數(shù)據(jù)標(biāo)志,以縮小查詢范圍,如時(shí)間。我們可以將上一頁(yè)的最長(zhǎng)時(shí)間作為查詢條件的一部分。SQL可以優(yōu)化如下: