You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardExpand all lines: content/en/altinity-kb-queries-and-syntax/jsonextract-to-parse-many-attributes-at-a-time.md
+32
Original file line number
Diff line number
Diff line change
@@ -40,3 +40,35 @@ select extractKeyValuePairs(p['data'])['action'] as data ,
40
40
format Vertical
41
41
```
42
42
43
+
For very subnested dynamic JSON files, if you don't need all the keys, you could parse sublevels specifically. Still this will require several JSONExtract calls but each call will have less data to parse so complexity will be reduced for each pass: O(log n)
INSERT INTO better_parsing FORMAT JSONAsString {"timestamp":"2024-06-12T14:30:00.001Z","functionality":"DOCUMENT","flowId":"210abdee-6de5-474a-83da-748def0facc1","step":"BEGIN","env":"dev","successful":true,"data":{"action":"initiate_view","stats":{"total":1,"success":1,"failed":0},"client_ip":"192.168.1.100","client_port":"8080"}}
48
+
49
+
WITH parsed_content AS
50
+
(
51
+
SELECT
52
+
JSONExtractKeysAndValues(json, 'String') AS 1st_level_arr,
53
+
mapFromArrays(1st_level_arr.1, 1st_level_arr.2) AS 1st_level_map,
54
+
JSONExtractKeysAndValues(1st_level_map['data'], 'String') AS 2nd_level_arr,
55
+
mapFromArrays(2nd_level_arr.1, 2nd_level_arr.2) AS 2nd_level_map,
56
+
JSONExtractKeysAndValues(2nd_level_map['stats'], 'String') AS 3rd_level_arr,
57
+
mapFromArrays(3rd_level_arr.1, 3rd_level_arr.2) AS 3rd_level_map
0 commit comments