9

JSONiq和XQuery 3.1扩展了XQuery 3.0,支持 JSON。

它们有何不同?

4

2 回答 2

11

整体动机

XQuery 3.1 的设计目标是支持内存中的其他数据结构(映射、数组)。这些结构映射到 JSON 用于输入和输出。自 2017 年 3 月以来,XQuery 3.1 一直是 W3C 推荐。

JSONiq 的设计目标是在文档存储等设置中查询和更新 JSON。它也是由 XML Query 工作组的成员(免责声明:我是其中之一)在研究支持 JSON 的各种可能性时设计的。虽然它不是官方推荐,但它是稳定且公开的。

数据模型

XQuery 3.1 和 JSONiq 都使用对象和数组扩展了数据模型,但是以不同的方式这样做,这是出于各自不同的关注点。总体而言,XQuery 3.1 具有更通用的数据模型,而 JSONiq 将其限制为镜像 JSON。

在 JSONiq 中,对象键必须是字符串。在 XQuery 3.1 中,它们可以是任何原子值。

在 JSONiq 中,对象和数组中的值必须是单个项,特别是数组与序列同态,即使它们是不同的。在 XQuery 3.1 中,对象和数组中的值可以是项序列。

在 JSONiq 中,空值用专用的原子类型表示。在 XQuery 3.1 中,它们用空序列(在数据模型中是可接受的值)表示。

在 XQuery 3.1 中,不通过填充数组或映射来复制值,这支持在 XML 节点上构建索引等。在 JSONiq 中,副本的制作类似于 XML 构造函数,以确保严格的树语义。

建造

在 JSONiq 中构造对象和数组的语法是 JSON 的超集。

{ "foo" : [ 1 to 10 ] }

在 XQuery 3.1 中,它类似于计算的 XML 节点构造函数:

map { "foo" : array { 1 to 10 } }

XQuery 3.1 为数组提供了另一种语法,其中逗号分隔值的槽,以嵌套序列:

[ 1, (1 to 10), 11 ]

导航

XQuery 3.1 使用函数调用在对象和数组中执行查找:

let $map := map { "foo" : "bar" }
return $map("foo")

let $array := array { 1, 2, 3 }
return $array(2)

它还?用作不带引号的名称和整数的快捷方式:

let $map := map { "foo" : "bar" }
return $map?foo

let $array := array { 1, 2, 3 }
return $array?2

let $array := array { 1, 2, 3 }
return $array?*

JSONiq(核心语言)使用点和方括号

let $map := { "foo" : "bar" }
return $map.foo

let $array := [ 1, 2, 3 ]
return $array[[2]]

let $array := [ 1, 2, 3 ]
return $array[]

(JSONiq 也作为 XQuery 的扩展存在,它也重载了函数调用语法)。

于 2017-07-05T07:19:11.883 回答
2

我对 XQuery 3.1 如何支持 Json 有点失望。

基本要求之一是完全兼容Json语法,就像XQuery兼容XML语法和JSONiq兼容Json语法一样,这样客户就可以从现有的Json文件开始。如果必须显式启用与 Json 兼容的语法,则可以接受序言。

不幸的是,在标准 XQuery 3.1 中,您必须map{...}为 Json 对象、true()Json 值 true、false()Json 值 false 和()Json 值 null 编写。将 Json 文件转换为 Json 模板会很痛苦。

XQuery 3.1 支持为纯文本模板散布字符串。如果将 Json 文件转换为纯文本模板,则必须小心处理 XQuery 返回值,因为它不关心 Json 数据类型和转义引用的字符串。

结论

JSONiq(仅在 Json 上工作时)和带有 JSONiq 扩展名的 XQuery(在 XML 和 Json 上工作时)是将 Json 文件转换为 Json 模板的更好解决方案。

于 2021-03-27T22:33:33.323 回答