圖形 API 總覽已大致介紹圖形 API 的專用術語和結構。本文將詳述 API 要求所產生的結果。
對節點或關係連線發出 API 要求時,您通常不會在單一回應中就收到這個要求的所有結果。這是因為某些回應可能包含數千個物件,所以系統會依預設將大多數回應進行分頁處理。
游標型分頁是最有效的分頁方法,應盡可能加以使用。游標指的是一個隨機字元字串,用於標示資料清單中的特定項目。游標會一律指向項目,但若刪除或移除項目,游標便會失效。因此,您的應用程式不應該儲存游標,或假設這些游標日後仍將有效。
讀取支援游標分頁的關係連線時,您會看到下列 JSON 回應:
{ "data": [ ... Endpoint data is here ], "paging": { "cursors": { "after": "MTAxNTExOTQ1MjAwNzI5NDE=", "before": "NDMyNzQyODI3OTQw" }, "previous": "https://graph.facebook.com/{your-user-id}/albums?limit=25&before=NDMyNzQyODI3OTQw" "next": "https://graph.facebook.com/{your-user-id}/albums?limit=25&after=MTAxNTExOTQ1MjAwNzI5NDE=" } }
游標分頁的關係連線支援下列參數:
before
:這是指向已傳回資料頁面開頭的游標。after
:這是指向已傳回資料頁面結尾的游標。limit
:這是可能傳回的物件數量上限。由於過濾的緣故,查詢時傳回的物件數量可能低於 limit
的值。請不要根據結果數量少於 limit
值的情形,而標示查詢已達到資料清單的結尾處,請改為使用未包含 next
的方式,如下所述。例如,如果您將 limit
設為 10,而系統傳回 9 筆結果,可能仍有更多資料可使用,但因為隱私過濾功能,而有一個項目遭移除。基於效能因素,某些關係連線的 limit
值同樣具有上限。無論什麼情況,API 都會傳回正確的分頁連結。next
:將傳回下一頁資料的圖形 API 端點。如果未包含此參數,代表傳回資料為最後一頁。由於分頁作業配合能見度和隱私設定的方式,有可能某頁為空白,但卻包含 next
的分頁連結。當 next
連結不再出現時,請停止分頁。previous
:將傳回上一頁資料的圖形 API 端點。如果未包含此參數,代表傳回資料為第一頁。請勿儲存游標。如果新增或刪除項目,游標很快就會變成無效。
時間型分頁用於使用 Unix 時間戳記瀏覽結果資料,這些時間戳記會指向資料清單中的特定時間。
使用支援時間型分頁的端點時,您會看到下列 JSON 回應:
{ "data": [ ... Endpoint data is here ], "paging": { "previous": "https://graph.facebook.com/{your-user-id}/feed?limit=25&since=1364849754", "next": "https://graph.facebook.com/{your-user-id}/feed?limit=25&until=1364587774" } }
時間型分頁的關係連線支援下列參數:
until
:Unix 時間戳記或 strtotime
資料值,可指向時間型資料範圍的結尾。since
:Unix 時間戳記或 strtotime
資料值,可指向時間型資料範圍的開頭。limit
:這是可能傳回的物件數量上限。由於過濾的緣故,查詢時傳回的物件數量可能低於 limit
的值。請不要根據結果數量少於 limit
值的情形,而標示查詢已來到資料清單的結尾處,請改為使用未包含 next
的方式,如下所述。例如,如果您將 limit
設為 10,而系統傳回 9 筆結果,可能仍有更多資料可使用,但因為隱私過濾功能,而有一個項目遭移除。基於效能因素,某些關係連線的 limit
值同樣具有上限。無論什麼情況,API 都會傳回正確的分頁連結。next
:將傳回下一頁資料的圖形 API 端點。previous
:將傳回上一頁資料的圖形 API 端點。為了一致的結果,請同時指定 since
和 until
參數。此外,建議時間差最多為 6 個月。
當您不在乎時間順序,而只想要傳回特定數目的物件時,可使用位移分頁。只有當關係連線不支援游標型或時間型分頁時,才使用位移型分頁。
位移型分頁的關係連線支援下列參數:
offset
:依指定數目,將每一頁開頭位移。limit
:這是可能傳回的物件數量上限。由於過濾的緣故,查詢時傳回的物件數量可能低於 limit
的值。請不要根據結果數量少於 limit
值的情形,而標示查詢已達到資料清單的結尾處,請改為使用未包含 next
的方式,如下所述。例如,如果您將 limit
設為 10,而系統傳回 9 筆結果,可能仍有更多資料可使用,但因為隱私過濾功能,而有一個項目遭移除。基於效能因素,某些關係連線的 limit
值同樣具有上限。無論什麼情況,API 都會傳回正確的分頁連結。next
:將傳回下一頁資料的圖形 API 端點。如果未包含此參數,代表傳回資料為最後一頁。由於分頁作業配合能見度和隱私設定的方式,有可能某頁為空白,但卻包含 next
的分頁連結。當 next
連結不再出現時,請停止分頁。previous
:將傳回上一頁資料的圖形 API 端點。如果未包含此參數,代表傳回資料為第一頁。請注意,如果將新的物件加入分頁中的項目清單,每個位移型頁面的內容都會變更。
並非所有 API 呼叫都支援位移型分頁。若要取得一致的結果,建議您使用在回應中傳回的上一頁/下一頁連結來進行分頁。
如果物件傳回許多項目,例如數萬則留言,則可能會在分頁時受到限制。當應用程式已達到游標限制時,API 會傳回錯誤:
{ "error": { "message": "(#100) The After Cursor specified exceeds the max limit supported by this endpoint", "type": "OAuthException", "code": 100 } }