JSON_POINTER_EXTRACT_TEXT

Accepts a JSON document and pointer expression. If the key exists and the value is a JSON string, JSON_POINTER_EXTRACT_TEXT returns it as SQL TEXT, removing outer quotes and decoding characters. Otherwise, it returns NULL.

Syntax

JSON_POINTER_EXTRACT_TEXT
(<json>, <json_pointer_expression>)

Parameters

Parameter Description Supported input types
<json> The JSON document. TEXT
<json_pointer_expression> A JSON pointer expression to the location of the desired sub-document in the JSON. For more information, see JSON pointer expression syntax. TEXT

Return Type

TEXT

  • If any input values are NULL, the function will return NULL.

Examples

For the JSON document indicated by <json_common_example> below, see JSON common example. The returned result is based on the following example.

Example

The following code example extracts the value at path /value/uid from the JSON document, removes the outermost quotes, and returns the result as SQL TEXT, labeled as res:

SELECT JSON_POINTER_EXTRACT_TEXT('{"value": {"uid": "987654"} }', '/value/uid') AS res

Returns

The previous code example returns the following:

res (TEXT)
987654

Example

The following code example attempts to extract the value at the path /value/no_such_key from the JSON document:

SELECT JSON_POINTER_EXTRACT_TEXT('{"value": {"uid": "987654"} }', '/value/no_such_key') AS res

Returns

The previous code example returns the NULL with the result labeled as res, because the key does not exist:

res (TEXT)
NULL

Example

The following code example attempts to extract the value at the path /value/code from the JSON document:

SELECT JSON_POINTER_EXTRACT_TEXT('{"value": {"code": 12} }', '/value/code') AS res

Returns

The previous code example returns NULL, labeled as res because the value at the specified path is an integer, not a string:

res (TEXT)
NULL

Example

The following code example navigates to the third element at index 2 of the array at /value/keywords in the JSON document, removes the outermost quotes, and returns it as SQL TEXT, labeled as res:

SELECT JSON_POINTER_EXTRACT_TEXT(<json_common_example>,'/value/keywords/2') AS res

Returns

The previous code example returns "analytics", which is the third element in the JSON array, which uses zero-based indexing:

res (TEXT)
analytics