Pagina los resultados de las consultas

Para controlar conjuntos de resultados que contengan 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 de forma automática 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 mostrará. Si no se especifica, se muestra 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 page_token. Cuando se proporciona un page_token, todos los demás parámetros de la llamada deben coincidir con la llamada anterior que mostró 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 consulta, supongamos que la cuenta contiene 100,000 offer_ids y el page_size está configurado en 200. El conjunto de resultados contendrá 200 objetos ReportRow en la primera respuesta, junto con un next_page_token.

Para recuperar las 200 filas siguientes, 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 de cuerpo de respuesta (los primeros cinco resultados más 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"
}