Consulta datos de columnas

En esta página, se describe cómo ejecutar consultas en datos organizados en columnas.

Consulta datos de columnas

El motor de consultas de Spanner analiza las consultas y selecciona automáticamente el formato columnar si es beneficioso. Sin embargo, es posible que varias clases de búsquedas aún necesiten la sugerencia de búsqueda para usar el formato columnar. A continuación, se muestran ejemplos de cómo usar la sugerencia de consulta @{scan_method=columnar}:

  • @{scan_method=columnar} SELECT COUNT(*) FROM Singers;
  • SELECT COUNT(*) FROM Singers @{scan_method=columnar};
  • @{scan_method=columnar} SELECT m.MsgBlob FROM Messages WHERE m.id='1234';

Además, puedes inhabilitar explícitamente la selección automática de columnas con la sugerencia de consulta @{scan_method=no_columnar}.

Consulta datos en columnas de Spanner con consultas federadas de BigQuery

Para leer datos de columnas de Spanner desde BigQuery, puedes crear un conjunto de datos externo o usar la función EXTERNAL_QUERY.

Cuando consultas conjuntos de datos externos, los datos en formato de columnas se usan automáticamente si están disponibles y son adecuados para tu consulta.

Si usas la función EXTERNAL_QUERY, Spanner usa automáticamente los datos en formato de columnas si están disponibles y son adecuados para la carga de trabajo. También puedes incluir la sugerencia @{scan_method=columnar} en la consulta anidada de Spanner.

En el siguiente ejemplo, se muestra cómo usar la sugerencia de consulta:

  • El primer argumento de EXTERNAL_QUERY especifica la conexión externa y el conjunto de datos, my-project.us.albums.
  • El segundo argumento es una consulta en SQL que selecciona MarketingBudget de la tabla AlbumInfo donde MarketingBudget es inferior a 500,000.
  • La sugerencia @{scan_method=columnar} optimiza la consulta externa para el análisis columnar.
  • La instrucción SELECT externa calcula la suma de los valores de MarketingBudget que devuelve la consulta externa.
  • La cláusula AS total_marketing_spend asigna un alias a la suma calculada.
SELECT SUM(MarketingBudget) AS total_marketing_spend
FROM
  EXTERNAL_QUERY(
    'my-project.us.albums',
    '@{scan_method=columnar} SELECT AlbumInfo.MarketingBudget FROM AlbumInfo WHERE AlbumInfo.MarketingBudget < 500000;');

¿Qué sigue?