JSONiq和XQuery 3.1都扩展了XQuery 3.0,支持 JSON。
它们有何不同?
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 的扩展存在,它也重载了函数调用语法)。
我对 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 模板的更好解决方案。