|
| 1 | +-- Demo: JSON parsing and VARIANT field access |
| 2 | +-- Covers: get_json_object, from_json, json_tuple → PARSE_JSON + bracket access |
| 3 | + |
| 4 | +CREATE TABLE IF NOT EXISTS raw_events ( |
| 5 | + event_id STRING NOT NULL, |
| 6 | + event_type STRING, |
| 7 | + payload STRING, |
| 8 | + occurred_at TIMESTAMP, |
| 9 | + CONSTRAINT raw_events_pk PRIMARY KEY (event_id) |
| 10 | +) |
| 11 | +USING DELTA; |
| 12 | + |
| 13 | +CREATE TABLE IF NOT EXISTS user_profiles ( |
| 14 | + user_id STRING NOT NULL, |
| 15 | + metadata STRING, |
| 16 | + CONSTRAINT user_profiles_pk PRIMARY KEY (user_id) |
| 17 | +) |
| 18 | +USING DELTA; |
| 19 | + |
| 20 | +-- Extract typed fields from a JSON payload column |
| 21 | +CREATE OR REPLACE TEMP VIEW parsed_events AS |
| 22 | +SELECT |
| 23 | + event_id, |
| 24 | + event_type, |
| 25 | + occurred_at, |
| 26 | + get_json_object(payload, '$.user_id') AS user_id, |
| 27 | + get_json_object(payload, '$.amount') AS amount_str, |
| 28 | + CAST(get_json_object(payload, '$.amount') AS DOUBLE) AS amount, |
| 29 | + get_json_object(payload, '$.currency') AS currency, |
| 30 | + get_json_object(payload, '$.items[0]') AS first_item |
| 31 | +FROM raw_events; |
| 32 | + |
| 33 | +-- Aggregate per user, parsing nested JSON |
| 34 | +CREATE OR REPLACE TEMP VIEW user_event_summary AS |
| 35 | +SELECT |
| 36 | + get_json_object(payload, '$.user_id') AS user_id, |
| 37 | + COUNT(*) AS event_count, |
| 38 | + SUM(CAST(get_json_object(payload, '$.amount') AS DOUBLE)) AS total_amount, |
| 39 | + MIN(occurred_at) AS first_event, |
| 40 | + MAX(occurred_at) AS last_event |
| 41 | +FROM raw_events |
| 42 | +WHERE event_type = 'purchase' |
| 43 | +GROUP BY get_json_object(payload, '$.user_id'); |
0 commit comments