Einführung in Snowflake SQL
George Boorman
Senior Curriculum Manager, DataCamp
Beispiel für strukturierte Daten
| 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 |
Beispiel für halbstrukturierte Daten

cust_id: 1
Vergleiche
JSONBVARIANTVARIANT Unterstützt die Datentypen OBJECT und ARRAY{ "key": "value"}["list", "of", "values"]CREATE TABLE cust_info_json_data (
customer_id
customer_info VARIANT -- Datentyp VARIANT
);
PARSE_JSON
expr: JSON-Daten im String-FormatVARIANT “, gültiges JSON-ObjektBeispiel:
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
SELECT OBJECT_CONSTRUCT(
-- Comma separated values rather than : notation
'cust_id', 1,
'cust_name', 'cust1',
'cust_age', 40,
'cust_email', 'cust1***@gmail.com'
)

Simple JSON
:SELECT
customer_info:cust_age, -- Use colon to access cust_age from column
customer_info:cust_name,
customer_info:cust_email,
FROM
cust_info_json_data;

Beispiel für verschachtelte JSON-Daten

:.Auf Werte mit Doppelpunkt-Notation zugreifen
<column>:<level1_element>:<level2_element>:<level3_element>
SELECT
customer_info:address:street AS street_name
FROM
cust_info_json_data

Auf Werte mit der Punktnotation zugreifen
<column>:<level1_element>.<level2_element>.<level3_element>
SELECT
customer_info:address.street AS street_name
FROM
cust_info_json_data

Einführung in Snowflake SQL