Tipi di dati e funzioni in Snowflake
Jake Roach
Field Data Engineer
school_id | school_name | street_number | street_name | suffix | city | zip_code
----------- | ----------------- | --------------- | ------------- | --------- | -------------- | ----------
s_19219 | West Aurora HS | 879 | Main | St. | West Aurora | 25041
s_77465 | Springtown HS | 1645 | Cherry | Rd. | Springtown | 14556
school_id | address_info
----------- | ------------------------------------------
s_19219 | {
| "school_name": "West Aurora HS",
| "address": {
| "street_number": 879,
| "street_name": "Main",
| "suffix": "St."
| "city": "West Aurora",
| "zip_code": 25041
| }
| }
I dati con parentesi graffe in coppie chiave-valore hanno tipo VARIANT
{
"school_name": "West Aurora HS",
"address": { -- Oggetto annidato
"street_number": 879,
"street_name": "Main",
"suffix": "St.",
"city": "West Aurora",
"zip_code": 25041
}
}
$$
$$
$$
address my_column
-------------------------------------------
{
"my_first_key": 2025,
"my_second_key": {
"a": "alpha",
"b": "bravo"
}
}
SELECTmy_column:my_first_key -- Top-levelmy_column:my_second_key.a -- Annidato my_column:my_second_key.b -- Annidato...
Rende facile recuperare valori top-level e annidati dai dati VARIANT
$$
<column-name>:<top-level-key>. e il campo annidato, <column-name>:<top-level-key>.<nested-key> SELECT
address_info:school_name, -- Top-level, notazione con punto
address_info:address.street_number AS street_number, -- Annidato, notazione con punto
address_info:address.street_name AS street_name,
address_info:address.suffix AS suffix
FROM SCHOOLS.school_info;
school_name | street_number | street_name | suffix
----------------- | --------------- | ------------- | ---------
West Aurora HS | 879 | Main | St.
Springtown HS | 1645 | Cherry | Rd.
Offre un altro modo per recuperare valori al top-level e annidati
$$
<column-name>['<top-level-key']['...']')! my_column
------------------------------------------------
{
"my_first_key": 2025,
my_second_key": {
"a": "alpha",
"b": "bravo"
}
}
SELECTmy_column['my_first_key'], -- Top-levelmy_column['my_second_key']['a'] -- Annidato my_column['my_second_key']['b'] -- Annidato...
SELECTaddress_info['school_name'], -- Top-level, notazione con parentesiaddress_info['address']['city'] AS city, -- Annidato, notazione con parentesi address_info['address']['zip_code'] AS zip_codeFROM SCHOOLS.school_info;
school_name | city | zip_code
----------------- | -------------- | ----------
West Aurora HS | West Aurora | 25041
Springtown HS | Springtown | 14556
SELECT
school_id,
address_info:school_name AS school_name, -- Top-level, dot-notation
address_info:address.street_number AS street_number, -- Annidato, dot-notation
address_info:address.street_name AS street_name,
address_info:address.suffix AS suffix,
address_info['address']['city'] AS city, -- Annidato, notazione con parentesi
address_info['address']['zip_code'] AS zip_code
FROM SCHOOLS.school_info;
school_id | address_info
----------- | ------------------------------------------
s_19219 | {
| "school_name": "West Aurora HS",
| "address": {
| "street_number": 879,
| "street_name": "Main",
| "suffix": "St."
| "city": "West Aurora",
| "zip_code": 25041
| }
| }
school_id | school_name | street_number | street_name | suffix | city | zip_code
----------- | ----------------- | --------------- | ------------- | --------- | -------------- | ----------
s_19219 | West Aurora HS | 879 | Main | St. | West Aurora | 25041
s_77465 | Springtown HS | 1645 | Cherry | Rd. | Springtown | 14556
Tipi di dati e funzioni in Snowflake