forked from folio-org/folio-analytics
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpo_prod_ids.sql
30 lines (24 loc) · 981 Bytes
/
po_prod_ids.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
DROP TABLE IF EXISTS po_prod_ids;
CREATE TABLE po_prod_ids AS
WITH po_prod_id AS (
SELECT
pl.id AS pol_id,
pl.po_line_number AS pol_number,
json_extract_path_text(product_ids.data, 'productId') AS prod_id,
json_extract_path_text(product_ids.data, 'productIdType') AS prod_id_type
FROM
po_lines AS pl
CROSS JOIN json_extract_path(pl.data, 'details') AS details (data)
CROSS JOIN json_array_elements(json_extract_path(details.data, 'productIds')) AS product_ids (data))
SELECT
pol_number,
prod_id,
inventory_identifier_types.name AS prod_id_type_name
FROM
po_prod_id
LEFT JOIN po_purchase_orders AS ppo ON po_prod_id.pol_id = ppo.id
LEFT JOIN inventory_identifier_types ON po_prod_id.prod_id_type = inventory_identifier_types.id;
CREATE INDEX ON po_prod_ids (pol_number);
CREATE INDEX ON po_prod_ids (prod_id);
CREATE INDEX ON po_prod_ids (prod_id_type_name);
VACUUM ANALYZE po_prod_ids;