Para controlar los conjuntos de resultados que contienen una gran cantidad de filas, el lenguaje de consultas de Merchant Center admite la paginación. Hay dos parámetros disponibles para controlar la paginación en el cuerpo de la solicitud reports.search
: page_size
y page_token
, además de un campo de salida en el cuerpo de la respuesta: next_page_token
.
El parámetro page_size
especifica la cantidad máxima de filas que se recuperarán en una sola solicitud. Si no se especifica, se establece automáticamente en el tamaño de página máximo de 1,000 filas.
El parámetro page_token
especifica el token de la página que se devolverá. Si no se especifica, se devuelve la primera página. Para recuperar una página posterior, el valor recibido como next_page_token
de la llamada reports.search
anterior se debe proporcionar como un page_token
. Cuando se proporciona un page_token
, todos los demás parámetros de la llamada deben coincidir con la llamada anterior que devolvió el page_token
para evitar un comportamiento inesperado.
Ejemplo:
SELECT
segments.offer_id,
metrics.impressions,
metrics.clicks,
metrics.ctr
FROM MerchantPerformanceView
WHERE segments.date BETWEEN '2021-12-01' AND '2021-12-31'
Para esta búsqueda, supón que la cuenta contiene 100,000 offer_ids
y que el page_size
está establecido en 200. El conjunto de resultados contendrá 200 objetos ReportRow
en la primera respuesta, junto con un next_page_token
.
Para recuperar las siguientes 200 filas, vuelve a enviar la solicitud con el mismo tamaño de página, pero actualiza el page_token
de la solicitud al next_page_token
de la respuesta anterior.
A continuación, se muestra un ejemplo del cuerpo de la respuesta (los primeros cinco resultados más el next_page_token
):
{
"results": [
{
"segments": {
"offerId": "12345"
},
"metrics": {
"clicks": "0",
"impressions": "59",
"ctr": 0
}
},
{
"segments": {
"offerId": "12346"
},
"metrics": {
"clicks": "9625",
"impressions": "276695",
"ctr": 0.034785594246372356
}
},
{
"segments": {
"offerId": "12347"
},
"metrics": {
"clicks": "148",
"impressions": "22045",
"ctr": 0.0067135404853708325
}
},
{
"segments": {
"offerId": "12348"
},
"metrics": {
"clicks": "11",
"impressions": "1100",
"ctr": 0.01
}
},
{
"segments": {
"offerId": "12349"
},
"metrics": {
"clicks": "569",
"impressions": "62977",
"ctr": 0.0090350445400701838
}
},
...
],
"nextPageToken": "CMgB"
}