如何从Oracle JSON CLOB类型的JSON数组中选择特定元素

How to select specific element from a JSON array in Oracles JSON CLOB type(如何从Oracle JSON CLOB类型的JSON数组中选择特定元素)
本文介绍了如何从Oracle JSON CLOB类型的JSON数组中选择特定元素的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个CLOB专栏,其中包含以下数据(为此问题而简化)

{
    "notUsed": [],
    "stock": [
        {
            "name": "eggs",
            "value": "in stock"
        },
        {
            "name": "milk",
            "value": "out of stock"
        }
    ]
}

我希望避免选择整个对象并通过编程进行解析来获得我想要的数据。理想情况下,我希望使用Oracle JSON path功能来完成此操作。

我想获取"value",其中"name" = "eggs"

我尝试了以下方法,但得到了[99999][40442] ORA-40442: JSON path expression syntax error。我通过一个evaluator运行了上面的示例JSON和JSON路径,它返回了所需的结果,这让我认为Oracle有它自己的JSONPath解释

SELECT
  json_query(
                 '{"notUsed":[],"stock":[{"name":"eggs","value":"in stock"}, {"name":"milk","value":"out of stock"}]}',
                 '$.stock[?(@.name=="eggs")]' )
FROM dual;

我也尝试过使用Dot Notation,但找不到将WHERE子句添加到数组属性的示例。

select
  myTable.id,
  myTable.JSON_COLUMN.stock    -- how to get array element here?
from MY_TABLE myTable
where j.id = 46

版本:

SELECT * FROM V$VERSION

Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production
PL/SQL Release 12.1.0.2.0 - Production
"CORE   12.1.0.2.0  Production"

推荐答案

JSON_PATH_EXPRESSION仅支持一些基本语法,the manual:

JSON_path_expression::=

Object_Step::=

ARRAY_STEP::=

另一种方法是使用JSON_TABLE将JSON转换为关系表,然后投影和筛选列。

select value
from json_table(
    '{
        "notUsed": [],
        "stock": [
            {
                "name": "eggs",
                "value": "in stock"
            },
            {
                "name": "milk",
                "value": "out of stock"
            }
        ]
    }',
    '$.stock[*]'
    columns
    (
        name varchar2(100 char) path '$.name',
        value varchar2(100 char) path '$.value'
    )
)
where name = 'eggs'

结果:

VALUE
-----
in stock

这篇关于如何从Oracle JSON CLOB类型的JSON数组中选择特定元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

SQL to Generate Periodic Snapshots from Transactions Table(用于从事务表生成定期快照的SQL)
MyBatis support for multiple databases(MyBatis支持多个数据库)
Oracle 12c SQL: Missing column Headers in result(Oracle 12c SQL:结果中缺少列标题)
SQL query to find the number of customers who shopped for 3 consecutive days in month of January 2020(查询2020年1月连续购物3天的客户数量)
How to get top 10 data weekly (This week, Previous week, Last month, 2 months ago, 3 month ago)(如何每周获取前十大数据(本周、前一周、上个月、2个月前、3个月前))
Select the latest record for an Id per day - Oracle pl sql(选择每天ID的最新记录-Oracle pl SQL)