我們在專案中常常需要快取需要分頁的數據,有以下幾種思路,我們來比較一下各自優劣
幾種想法:
每頁資料分別使用一個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中文網其他相關文章!