Redshift’e Giriş
Jason Myers
Principal Architect
SUPER türünde saklanırIS_VALID_JSON - bir tüm JSON nesnesinin geçerli olduğunu doğrularSELECT 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 bir JSON yolundaki değeri döndürürSELECT JSON_EXTRACT_PATH_TEXT('{"one":1, "two":2}', 'one');
JSON_EXTRACT_PATH_TEXT
======================
1
-- Kötü biçimlendirilmiş JSON'dan yol çıkarmaya çalışma
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
NULL dönerSELECT 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 dizi indeksindeki değeri döndürür 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]
}',
-- JSON_EXTRACT_PATH_TEXT ile nested_two değerini çıkarma
'nested_two'
),
-- JSON_EXTRACT_ARRAY_ELEMENT_TEXT ile dizinin birinci konumundaki öğeyi çıkarma
1
);
JSON_EXTRACT_ARRAY_ELEMENT_TEXT
===============================
4
-- İki anahtar ('nested_two', '1') vererek
-- nested_two anahtarının dizisindeki ikinci öğeyi seçme
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
)
Redshift’e Giriş