Introductie tot Redshift
Jason Myers
Principal Architect
SUPERIS_VALID_JSON – controleert of een volledig JSON-object geldig isSELECT IS_VALID_JSON('{"one":1, "two":2}');
IS_VALID_JSON
=============
true
SELECT IS_VALID_JSON('{"one":1, "two":2');
IS_VALID_JSON
=============
false
SELECT IS_VALID_JSON_ARRAY('{"one":1}')
IS_VALID_JSON_ARRAY
===================
false
SELECT IS_VALID_JSON_ARRAY('[1,2,3]')
IS_VALID_JSON_ARRAY
===================
true
JSON_EXTRACT_PATH_TEXT geeft de waarde op een JSON-padSELECT JSON_EXTRACT_PATH_TEXT('{"one":1, "two":2}', 'one');
JSON_EXTRACT_PATH_TEXT
======================
1
-- Proberen een pad te extraheren uit slecht gevormde JSON
SELECT JSON_EXTRACT_PATH_TEXT('{"one":1, "two":2', 'one');
JSON parsing error
DETAIL:
=========================================
error: JSON parsing error
code: 8001
context: invalid json object
query: [child_sequence:'one']
location: funcs_json.hpp:202
process: padbmaster [pid=1073807529]
=========================================
SELECT JSON_EXTRACT_PATH_TEXT('
{
"one_object":{
"nested_three": 3,
"nested_four":4
},
"two":2
}',
'one_object', 'nested_three');
JSON_EXTRACT_PATH_TEXT
======================
3
NULLSELECT JSON_EXTRACT_PATH_TEXT('
{
"one_object":{
"nested_three": 3,
"nested_four":4
},
"two":2
}',
'two', 'nested_five');
JSON_EXTRACT_PATH_TEXT
======================
NULL
JSON_EXTRACT_ARRAY_ELEMENT_TEXT geeft de waarde op een array-index SELECT JSON_EXTRACT_ARRAY_ELEMENT_TEXT('[1.1,400,13]', 2);
JSON_EXTRACT_ARRAY_ELEMENT_TEXT
===============================
13
SELECT JSON_EXTRACT_ARRAY_ELEMENT_TEXT('[1.1,400,13]', 3);
JSON_EXTRACT_ARRAY_ELEMENT_TEXT
===============================
NULL
SELECT JSON_EXTRACT_ARRAY_ELEMENT_TEXT(
JSON_EXTRACT_PATH_TEXT('
{
"one":1,
"nested_two":[3,4,5]
}',
-- Waarde bij nested_two ophalen met JSON_EXTRACT_PATH_TEXT
'nested_two'
),
-- Item op positie één van de array ophalen met JSON_EXTRACT_ARRAY_ELEMENT_TEXT
1
);
JSON_EXTRACT_ARRAY_ELEMENT_TEXT
===============================
4
-- Twee sleutels ('nested_two', '1') doorgeven om
-- het tweede element van de arraywaarde van nested_two te kiezen
SELECT JSON_EXTRACT_PATH_TEXT('
{
"one":1,
"nested_two":[3,4,5]
}',
'nested_two', '1'
);
JSON_EXTRACT_PATH_TEXT
======================
4
WITH location_details AS (
SELECT '{
"location": "Salmon Challis National Forest",
}'::SUPER::VARCHAR AS data
)
Introductie tot Redshift