首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JSON对象是空的,但是它的子对象不是空的吗?

JSON对象是空的,但是它的子对象不是空的吗?
EN

Stack Overflow用户
提问于 2018-10-29 03:25:30
回答 1查看 129关注 0票数 0

我被以下明显的矛盾弄糊涂了:

代码语言:javascript
复制
select json_extract_scalar('{"json_array":[{"array_field":"1"}]}', 
                           '$.json_array') is null,
       json_extract_scalar('{"json_array":[{"array_field":"1"}]}', 
                           '$.json_array[0]') is null,
       json_extract_scalar('{"json_array":[{"array_field":"1"}]}', 
                           '$.json_array[0].array_field') is null

结果:

代码语言:javascript
复制
true  true false

为什么json_arrayNULL,但是当进一步挖掘的时候,它会突然恢复为非空的?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-29 08:08:07

这是因为您使用的是json_extract_scalar而不是json_extract。如果json路径的目标不是标量,则json_extract_scalar返回标量(不是数组或对象之类的组合)或NULL。

比较这些表达式。区别是使用json_extract_scalar和其他json_extract

代码语言:javascript
复制
presto> select json_extract_scalar('{"json_array":[{"array_field":"1"}]}', '$.json_array'),
     -> json_extract('{"json_array":[{"array_field":"1"}]}', '$.json_array');
 _col0 |         _col1
-------+-----------------------
 NULL  | [{"array_field":"1"}]
(1 row)
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53038338

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档