Introductie tot Snowflake SQL
George Boorman
Senior Curriculum Manager, DataCamp
Voorbeeld van gestructureerde data
| cust_id | cust_name | cust_age | cust_email |
|---------|-----------|----------|-----------------------|
| 1 | cust1 | 40 | cust1***@gmail.com |
| 2 | cust2 | 35 | cust2***@gmail.com |
| 3 | cust3 | 42 | cust3***@gmail.com |
Voorbeeld van semi-gestructureerde data

cust_id: 1
Vergelijking:
JSONBVARIANTVARIANT ondersteunt OBJECT- en ARRAY-typen{ "key": "value"}["list", "of", "values"]CREATE TABLE cust_info_json_data (
customer_id INT,
customer_info VARIANT -- VARIANT data type
);
PARSE_JSON
expr: JSON-data als stringVARIANT, geldig JSON-objectVoorbeeld:
SELECT PARSE_JSON(
-- Enclosed in strings
'{
"cust_id": 1,
"cust_name": "cust1",
"cust_age": 40,
"cust_email":"cust1***@gmail.com"
}
'-- Enclosed in strings
) AS customer_info_json

OBJECT_CONSTRUCT
OBJECT_CONSTRUCT( [<key1>, <value1> [, <keyN>, <valueN> ...]] ) SELECT OBJECT_CONSTRUCT(
-- Comma separated values rather than : notation
'cust_id', 1,
'cust_name', 'cust1',
'cust_age', 40,
'cust_email', 'cust1***@gmail.com'
)

Eenvoudige JSON
:SELECT
customer_info:cust_age, -- Gebruik dubbelepunt om cust_age uit kolom te halen
customer_info:cust_name,
customer_info:cust_email,
FROM
cust_info_json_data;

Voorbeeld van geneste JSON

:.Waarden benaderen met dubbelepuntnotatie
<column>:<level1_element>:<level2_element>:<level3_element>
SELECT
customer_info:address:street AS street_name
FROM
cust_info_json_data

Waarden benaderen met puntnotatie
<column>:<level1_element>.<level2_element>.<level3_element>
SELECT
customer_info:address.street AS street_name
FROM
cust_info_json_data

Introductie tot Snowflake SQL