首頁  >  文章  >  資料庫  >  redis如何快取分頁數據

redis如何快取分頁數據

(*-*)浩
(*-*)浩原創
2019-11-28 10:34:566469瀏覽

我們在專案中常常需要快取需要分頁的數據,有以下幾種思路,我們來比較一下各自優劣

redis如何快取分頁數據

幾種想法:

每頁資料分別使用一個key緩存,各自設定過期時間,在資料請求時且快取沒有時進行初始化,pageIndex和pageSize作為快取key的一部份,例如:      (建議學習:Redis影片教學

 key:cstm:list:${pageIndex}_${pageSize}

value:序列化(List)

每頁數據分別使用一個key緩存,在數據有更新時,主動更新所有頁的數據,pageIndex和pageSize作為緩存key的一部分,例如:

key:cstm:list:${pageIndex}_${pageSize}

value:序列化(List)

使用有序集合快取熱點數據,排序條件作為分數,使用指令【ZRANGE key start stop [WITHSCORES]】實現分頁效果

key:cstm:zset:pageList

value:序列化(Customer)

優劣分析:

第一種方式:在資料新增、刪除間隙初始化快取會產生,資料重複,或遺漏,例如:在第一頁資料快取完成後,資料有新增的話,在快取第二頁資料時,兩頁快取資料會有重複

第二種方式:若資料更新頻繁,快取資料會比較頻繁的更新

第三種方式:這種方式相對比較友好,需要在資料變更的同時維護緩存,並注意修剪清單長度

更多Redis相關技術文章,請造訪Redis入門教學欄位進行學習!

以上是redis如何快取分頁數據的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn