你說的數據重複是這樣麼,在翻頁的過程中,有人插入了一條數據,然後第一頁的最後一條數據被再次分配到了第二頁,變成了第二頁的第一條輸出,這條數據出現了兩次?
如果是這個意思的話,我建議你分頁在客戶端做,查詢的時候加個時間點,小於點擊查詢按鈕的時間的資料會被查出來,然後在客戶端進行分頁,這樣有新資料也不會影響分頁,因為新資料根本沒有取回。由於你這個是時間倒敘,即使有新資料也不會被看到,不會產生資料遺漏。在資料再次載入的時候,再去取數據,新數據就會被查詢出來。
前段時間剛處理了移動端類似的問題,說下移動端的思路:
1,首先是分為向下拉(獲取最新數據)和向上滑(獲取之前數據)
2,其次在每次向上滑獲取之前資料時,我都會傳一個id,透過這個id做為條件取得資料。你是時間倒序,那基本上可以認定id也是倒序,剛剛傳的id應該是之前獲取數據中最小的id,除第一次外,以後每次獲取數據都是小於這個id的數據
3,第一次取得資料的時候,因為沒有id,所以按順序取得最前面的資料即可。
希望對你的問題有幫助!
不好意思竟然是世界上最好的語言。
而我回答是基於nodejs的。
不過不影響,理解思路就好。
-------原答案------
我在看coding.net的api的時候發現他有兩種more的方式。
語法基於mongoose
一是通過分頁,pagify。例如一頁20的話,Model.find(query).skip(page*20 - 20).limit(20)。
二是用過加載更多,具體來說就是after。我沒開發過這樣的,不確定mongodb有沒有after這樣的屬性。不過依賴一個sort裡的東西的話,還是比較簡單的,Model.find(query).sort('-time').where({time:{$gt:TIME}}).limit(20)
如果mongodb有類似after的話,那就更好了。 (筆記time可能會撞車,而id不會)
Model.find(query).sort('-time').after({id:ID}).limit(20)
GET https://coding.net/api/activities/projects_last?last_id=14959187