可用版本: Dev (3.21) | 最新 (3.20) | 3.19 | 3.18 | 3.17 | 3.16 | 3.15 | 3.14

JSON_VALUE

适用于 ✅ 开源版   ✅ 专业版   ✅ 企业版

JSON_VALUE 函数用于使用 JSON 路径表达式从 JSON 文档中提取内容。

SELECT json_value(
  '{"a":[1,2,3]}',
  '$.a[1]'
)
FROM dual
create.select(jsonValue(
          val(JSON.valueOf("{\"a\":[1,2,3]}")),
          "$.a[1]"
      )
      .fetch();

结果如下

+------------+
| json_value |
+------------+
| 2          |
+------------+

如果值不重要,您只想检查值的存在,请使用 JSON_EXISTS 谓词

方言支持

此示例使用 jOOQ

jsonValue(val(json("[1,2]")), "$[*]")

翻译成以下特定方言的表达式

BigQuery, DB2, MariaDB, Oracle

json_value('[1,2]', '$[*]')

ClickHouse

JSON_VALUE('[1,2]', '$[*]')

DuckDB

json_extract_string('[1,2]', '$[*]')

MySQL, SQLite

json_extract('[1,2]', '$[*]')

Postgres, YugabyteDB

jsonb_path_query_first(
  CAST('[1,2]' AS jsonb),
  cast('$[*]' as jsonpath)
)

SQLServer

(
  SELECT c
  FROM openjson('[1,2]', '$') WITH (c varchar(max) '$[*]')
)

ASE, Access, Aurora MySQL, Aurora Postgres, CockroachDB, Databricks, Derby, Exasol, Firebird, H2, HSQLDB, Hana, Informix, MemSQL, Redshift, SQLDataWarehouse, Snowflake, Sybase, Teradata, Trino, Vertica

/* UNSUPPORTED */
使用 jOOQ 3.21 生成。早期 jOOQ 版本的支持可能有所不同。 在我们的网站上翻译您自己的 SQL

引用此页

反馈

您对此页面有任何反馈吗? 我们很乐意听取您的意见!

The jOOQ Logo