BigQuery: поиск в массиве идентификаторов типа RECORD и соединение данных из вторичной таблицы с использованием SQL - PullRequest
0 голосов
/ 09 июля 2020

У меня есть структура данных, как показано ниже:

Продукты

| name  | region_ids             |
----------------------------------
| shoe  | c32, a43, x53          |
| hat   | c32, f42               |

# Schema
name                STRING  NULLABLE
region_ids          RECORD  REPEATED    
region_ids.value    STRING  NULLABLE    

Регионы

| _id |  name       |
---------------------
| c32 |  london     |
| a43 |  manchester |
| x53 |  bristol    |
| f42 |  liverpool  |

# Schema
_id                 STRING  NULLABLE
name                STRING  NULLABLE

I хотите найти массив «region_ids» и заменить их именем региона, чтобы получить таблицу, как показано ниже:

| _id |  name  | region_names                |
----------------------------------------------
| d22 |  shoe  | london, manchester, bristol |
| t64 |  hat   | london, liverpool           |

Как лучше всего сделать это, используя стандартный SQL?

Спасибо,

A

1 Ответ

1 голос
/ 09 июля 2020

Ниже для BigQuery Standard SQL

#standardSQL
SELECT p._id, p.name, 
  STRING_AGG(r.name, ', ' ORDER BY OFFSET) AS region_names 
FROM `project.dataset.Products` p,
UNNEST(region_ids) WITH OFFSET
LEFT JOIN `project.dataset.Regions` r
ON value = r._id
GROUP BY _id, name   

Вы можете протестировать, поиграть с приведенными выше примерами данных из вашего вопроса, как в примере ниже

#standardSQL
WITH `project.dataset.Products` AS (
  SELECT 'd22' _id, 'shoe' name, [STRUCT<value STRING>('c32'), STRUCT('a43'), STRUCT('x53')] region_ids UNION ALL
  SELECT 't64', 'hat', [STRUCT<value STRING>('c32'), STRUCT('f42')]
), `project.dataset.Regions` AS (
  SELECT 'c32' _id, 'london' name UNION ALL
  SELECT 'a43', 'manchester' UNION ALL
  SELECT 'x53', 'bristol' UNION ALL
  SELECT 'f42', 'liverpool' 
)
SELECT p._id, p.name, 
  STRING_AGG(r.name, ', ' ORDER BY OFFSET) AS region_names 
FROM `project.dataset.Products` p,
UNNEST(region_ids) WITH OFFSET
LEFT JOIN `project.dataset.Regions` r
ON value = r._id
GROUP BY _id, name   

Результат:

Row _id name    region_names     
1   d22 shoe    london, manchester, bristol  
2   t64 hat     london, liverpool      

На основе примера вывода в вашем вопросе - вы ожидаете region_names как строку со списком имен, разделенных запятыми Но, если вам нужен region_names как массив - вы можете заменить STRING_AGG(r.name, ', ' ORDER BY OFFSET) на ARRAY_AGG(r.name ORDER BY OFFSET)

...