JSON_ EXTRACT_ <type>
On this page
Extracts data from JSON, optionally based on a path specification.
When used with JSON object or array and a path specification, extracts data from the JSON object or array that matches the path specification.
When used with a JSON argument and no path specification, extracts data from the JSON to a value of <type>.
The following JSON_
functions are supported:
-
JSON_
is for all numeric data (equivalent to theEXTRACT_ DOUBLE ::%
JSON operator). -
JSON_
is for all text and binary types (equivalent to theEXTRACT_ STRING ::$
JSON operator).The result collation is controlled by the json_
engine variable.extract_ string_ collation Refer to Sync Variables Lists for more information. -
JSON_
is for all valid JSON types, includingEXTRACT_ JSON true
,false
, JSON maps, and JSON lists. -
JSON_
is for allEXTRACT_ BIGINT BIGINT
types.Other data types are handled as follows: Booleans (true and false) become 1 and 0, respectively. Floats are rounded as follows: 1. 4 becomes 1, while 1. 5 becomes 2. For all other data types, 0 is returned. Note
For more information on JSON operators
::
,::$
, and::%
, see Accessing Fields in a JSON Object.Also, see Character Encodings and Collation for information on overriding collation settings.
Syntax
JSON_EXTRACT_<type>(<json>, <keypath> [, ]);JSON_EXTRACT_<type>(<json>);
Arguments
-
json
: valid JSON, or the name of a JSON column. -
keypath
: (optional) The path specification; a comma-separated list of object keys or zero-indexed array positions.
Return Value
When JSON_
is used with a JSON object or array literal and a path specification, the return values are as listed below.
-
SQL
NULL
if value is JSON NULL (such as{"a": null}
), or if keyname does not exist. -
The extracted element if
<json>
is a valid JSON object or array and the path specified by the list of<keypath>
s exists in<json>
. -
SQL
NULL
if<json>
is not a valid JSON object or array or if the path specified by the list of<keypaths>
does not exist in<json>
. -
SQL
NULL
if<json>
is SQLNULL
, an empty string, a JSON string, a JSON number, a JSON boolean value, or an empty JSON object or array. -
JSON
null
forJSON_
if the value is JSONEXTRACT_ JSON null
(such as{"a": null}
). -
SQL
NULL
forJSON_
if the value is JSONEXTRACT_ STRING null
(such as{"a": null}
). -
0 for
JSON_
andEXTRACT_ BIGINT JSON_
if the value is JSONEXTRACT_ DOUBLE null
(such as{"a": null}
).
Refer to JSON_JSON_
when used with a JSON argument only.
JSON Computed Column Optimization
JSON computed column optimization allows the engine to parse JSON strings once per row and extract fields for computed columns instead of parsing the strings multiple times.optimize_
to true
.
Consider a table with a JSON column and multiple computed columns whose values are created by extracting fields from the JSON column.
Remarks
Performance
-
This optimization works best when there are a high number of computed columns and shorter keypaths.
That is, the optimization scales well as the number of computed columns increases and performs less well as keys get longer and more deeply nested. -
For best performance use short JSON keys, limit the number of keys in key paths, and avoid accessing non-leaf fields.
-
For deeply nested JSON data, set
optimize_
tojson_ computed_ column false
as performance of this optimization degrades with deep nesting.If the key length exceeds the default threshold of 1 MB, the optimized parsing is turned off. -
For extremely small JSON, disable the optimization by setting
optimize_
tojson_ computed_ column false
.
Usage
-
The optimization triggers when a JSON column is used at least twice across all computed column expressions within a single row.
It applies on a per-JSON-column basis for selective optimization. -
The first argument of the computed column expression must be a
JSON_
expression that references a JSON column.EXTRACT_ <type> -
This optimization is available only in
INSERT
andSELECT
statements.
Impact of Disabling optimize_ json_ computed_ column
When optimize_
is set to false
, the system parses the JSON string separately for each computed column expression.
JSON_ EXTRACT_ <type> with Path Specification
The following table summarizes the functionality and return types of JSON_
when both a JSON object or array literal and a path specification are provided as arguments.
|
Function |
Return |
Comments |
---|---|---|---|
JSON Object or Array Literal |
|
json or SQL |
Extracts the JSON value found at the path ( If the extracted object is a JSON string, quotes are not removed. Returns SQL |
|
string or SQL |
Extracts the JSON value found at the path ( If the extracted object is a JSON string, quotes are removed. Returns SQL |
|
|
integer or 0 |
If the extracted value is a JSON string, extracts a valid numeric prefix and rounds to an Integer. Otherwise, returns 0. |
|
|
double or 0 |
If the extracted value is a JSON string, extracts a valid numeric prefix. Otherwise, returns 0. |
JSON_ EXTRACT_ <type> - JSON Argument Only
The following table summarizes the functionality and return values of JSON_
over a JSON argument only.
For all functions, the return value matches the type of the function.JSON_
returns a JSON value, JSON_
returns a string value, and so on.
<json> |
Function |
Return |
Notes |
---|---|---|---|
SQL |
|
SQL |
|
Empty string |
|
SQL |
|
JSON |
|
JSON |
Returns JSON |
|
SQL |
||
Empty JSON Object |
|
|
Returns JSON value. |
|
|
Returns string value. |
|
|
|
Return value matches type of function. |
|
JSON boolean value |
|
|
Returns JSON value. |
|
|
Returns string value. |
|
|
|
Returns 1 for true, 0 for false. Return value matches type of function. |
|
JSON string |
|
"<string>" |
Does not remove quotes. |
|
<string > |
Removes quotes. |
|
|
numeric prefix or
|
If string has a valid numeric prefix, returns the numeric prefix, rounded appropriately. Returns 0 if the string does not have a valid numeric prefix. |
|
JSON number |
|
numeric value |
Returns JSON value. |
|
numeric value |
Returns string value. |
|
|
rounded numeric value |
Returns BIGINT. |
|
|
numeric value |
Returns DOUBLE. |
|
JSON object |
|
<json object> |
Extracts full object. |
|
0 |
Return value matches type of function. |
|
JSON array |
|
<json array> |
Extracts full array. |
|
|
Return value matches type of function. |
|
Invalid JSON |
|
SQL |
|
|
|
Multi-Argument Examples
Example 1
Extracts the value for beta.
SELECT JSON_EXTRACT_DOUBLE('{"alpha":1, "beta":2, "gamma": [3,4,5]}', 'beta')AS get_beta;
+----------+
| get_beta |
+----------+
| 2 |
+----------+
Example 2
Extracts value for 1 from an array.
SELECT JSON_EXTRACT_DOUBLE('[3,4,5]', 1) AS get_result;
+------------+
| get_result |
+------------+
| 4 |
+------------+
Note
Since JSON uses zero-indexed array positions, extracting with the path 0
will extract the value 3
and the path 1
will extract the value 4
as in the example above.
Example 3
Extracts the value for the path gamma
.
SELECT JSON_EXTRACT_JSON('{"alpha":1, "beta":2, "gamma": [3,4,5]}', 'gamma')AS get_gamma;
+-----------+
| get_gamma |
+-----------+
| [3,4,5] |
+-----------+
Example 4
Extracts the value for the path gamma.
.[3,4,5]
which is 4
in this example.
SELECT JSON_EXTRACT_JSON('{"alpha":1, "beta":2, "gamma": [3,4,5]}', 'gamma', 1)AS get_gamma;
+-----------+
| get_gamma |
+-----------+
| 4 |
+-----------+
Example 5
The result in the following example is NULL
as zeta has no value.
SELECT JSON_EXTRACT_JSON('{"alpha":1, "beta":2, "gamma": [3,4,5]}', 'zeta')AS get_zeta;
+-----------+
| get_zeta |
+-----------+
| NULL |
+-----------+
Example 6
The result in the next example is rounded up to the next whole integer.1.
the result would have been 1
.
SELECT JSON_EXTRACT_BIGINT('{"alpha":1, "beta":2, "gamma": [3,4,5], "delta":1.5}', 'delta')AS get_delta;
+-----------+
| get_delta |
+-----------+
| 2 |
+-----------+
Example 7
The value for the path gamma
is an array so the entire array is returned as a string value.
SELECT JSON_EXTRACT_STRING('{"alpha":1, "beta":2, "gamma": [3,4,5]}', 'gamma')AS get_gamma;
+-----------+
| get_gamma |
+-----------+
| [3,4,5] |
+-----------+
Example 8
Returns the value for the path gamma
which is a non-numeric string in this example.
SELECT JSON_EXTRACT_STRING('{"alpha":1, "beta":2, "gamma": "A string"}', 'gamma')AS get_gamma;
+-----------+
| get_gamma |
+-----------+
| A string |
+-----------+
Single Argument Examples
Example 1 - JSON_ EXTRACT_ JSON
Extract from a JSON string with " "
quotes.JSON_
function does not remove the " "
quotes from the string.
SELECT JSON_EXTRACT_JSON('"a string"');
+---------------------------------------------+
| JSON_EXTRACT_JSON('"a string"') |
+---------------------------------------------+
| "a string" |
+---------------------------------------------+
Extract from a string without " "
quotes.
SELECT JSON_EXTRACT_JSON('a string');
+----------------------------------------+
| JSON_EXTRACT_JSON('a string') |
+----------------------------------------+
| NULL |
+----------------------------------------+
The JSON_
function with one argument will return the JSON input if the input is valid JSON or SQL NULL
if the input is invalid JSON.
Extract from a JSON array.
SELECT JSON_EXTRACT_JSON('["array element"]');
+----------------------------------------+
| JSON_EXTRACT_JSON('["array element"]') |
+----------------------------------------+
| ["array element"] |
+----------------------------------------+
Extract from a JSON object with two key-value pairs, for which the values are arrays with a single element.
SELECT JSON_EXTRACT_JSON('{"key2":[2],"key3":[3]}');
+----------------------------------------------+
| JSON_EXTRACT_JSON('{"key2":[2],"key3":[3]}') |
+----------------------------------------------+
| {"key2":[2],"key3":[3]} |
+----------------------------------------------+
Example 2 - JSON_ EXTRACT_ STRING
Extract from a string.JSON_
function removes the " "
quotes from the string.
SELECT JSON_EXTRACT_STRING('"a string"');
+----------------------------------+
| JSON_EXTRACT_STRING('"a string"')|
+----------------------------------+
| a string |
+----------------------------------+
The JSON_
function will return the JSON input as a string if the input is valid JSON or SQL NULL
if the input is invalid JSON.
Extract from a JSON array with one element which is a string.
SELECT JSON_EXTRACT_STRING('["array element"]');
+------------------------------------------+
| JSON_EXTRACT_STRING('["array element"]') |
+------------------------------------------+
| ["array element"] |
+------------------------------------------+
Extract from a JSON object with two key-value pairs, for which the values are arrays with a single element.
SELECT JSON_EXTRACT_STRING('{"key2":[2],"key3":[3]}');
+------------------------------------------------+
| JSON_EXTRACT_STRING('{"key2":[2],"key3":[3]}') |
+------------------------------------------------+
| {"key2":[2],"key3":[3]} |
+------------------------------------------------+
Example 3 - JSON_ EXTRACT_ BIGINT
Extract from a JSON double value.
SELECT JSON_EXTRACT_BIGINT('3.14');
+-------------------------------+
| JSON_EXTRACT_BIGINT('3.14') |
+-------------------------------+
| 3 |
+-------------------------------+
Extract from a JSON string with a numeric prefix.
SELECT JSON_EXTRACT_BIGINT('"12.3a"');
+-------------------------------+
| JSON_EXTRACT_BIGINT('"12.3a"')|
+-------------------------------+
| 12 |
+-------------------------------+
Example 4 - JSON_ EXTRACT_ DOUBLE
Extract from a JSON double value.
SELECT JSON_EXTRACT_DOUBLE('3.14');
+-------------------------------+
| JSON_EXTRACT_DOUBLE('3.14') |
+-------------------------------+
| 3.14 |
+-------------------------------+
Extract from a JSON string containing a double value.
SELECT JSON_EXTRACT_DOUBLE('"12.3a"');
+-------------------------------+
| JSON_EXTRACT_DOUBLE('"12.3a"')|
+-------------------------------+
| 12.3 |
+-------------------------------+
JSON Computed Column Optimization Examples
Example 1
Uses the JSON computed column optimization to compute values from multiple JSON keys within a single row.
CREATE TABLE computed_table (json_data JSON,sum_ab AS JSON_EXTRACT_BIGINT(json_data, 'a') +JSON_EXTRACT_BIGINT(json_data, 'b') PERSISTED BIGINT,value_c AS JSON_EXTRACT_BIGINT(json_data, 'c') PERSISTED BIGINT);INSERT INTO computed_table (json_data) VALUES('{"a": 1, "b": 2, "c": 3}'),('{"a": 4, "b": 5, "c": 6}'),('{"a": 10, "b": 20, "c": 30}');SELECT sum_ab AS total_a_b, value_c AS extracted_c FROM computed_table;
+-----------+-------------+
| total_a_b | extracted_c |
+-----------+-------------+
| 30 | 30 |
| 9 | 6 |
| 3 | 3 |
+-----------+-------------+
Example 2 - Non Overlapping JSON Data
Uses the JSON computed column optimization to extract values from non-overlapping JSON data, where each computed column references a different key in the JSON.
CREATE TABLE novels (novel_data JSON,novel_name AS novel_data::name PERSISTED LONGTEXT,novel_author AS novel_data::author PERSISTED LONGTEXT);INSERT INTO novels (novel_data) VALUES('{"name": "To Kill a Mockingbird", "author": "Harper Lee"}'),('{"name": "1984", "author": "George Orwell"}'),('{"name": "Pride and Prejudice", "author": "Jane Austen"}'),('{"name": "The Great Gatsby", "author": "F. Scott Fitzgerald"}');SELECT novel_name, novel_author FROM novels;
+-------------------------+-----------------------+
| novel_name | novel_author |
+-------------------------+-----------------------+
| "The Great Gatsby" | "F. Scott Fitzgerald" |
| "To Kill a Mockingbird" | "Harper Lee" |
| "Pride and Prejudice" | "Jane Austen" |
| "1984" | "George Orwell" |
+-------------------------+-----------------------+
Example 3 - Nested JSON Data
Uses the JSON computed column optimization to handle nested JSON data, extract a nested array from a key in the JSON column, and store the result in a computed column.
CREATE TABLE employee (employee_data JSON,employee_info AS employee_data::a PERSISTED LONGTEXT);INSERT INTO employee (employee_data) VALUES('{"a": [{"name": "Alice Johnson", "designation": "Software Engineer"}, {"name": "Bob Smith", "designation": "Project Manager"}]}'),('{"a": [{"name": "Charlie Brown", "designation": "Data Analyst"}, {"name": "Diana Prince", "designation": "UX Designer"}]}');SELECT employee_info AS employee_details FROM employee;
+-------------------------------------------------------------------------------------------------------------------+
| employee_details |
+-------------------------------------------------------------------------------------------------------------------+
| [{"designation":"Data Analyst","name":"Charlie Brown"},{"designation":"UX Designer","name":"Diana Prince"}] |
| [{"designation":"Software Engineer","name":"Alice Johnson"},{"designation":"Project Manager","name":"Bob Smith"}] |
+-------------------------------------------------------------------------------------------------------------------+
Last modified: November 15, 2024