JSONiq:JSON查询语言

JSONiq是个构建在XQuery之上的新型查询语言。类似于SQL或是LINQ,它提供了诸如let、for、where、group by与select等语法支持概念,参见如下代码示例:

let $stats := db:find("stats")
for $access in $stats
where $access("response_time") > 5
group by $url := $access("url")
return
{
    "url": $url,
    "avg": avg($access("response_time")),
    "hits": count($access)
}

JSONiq不仅仅支持JSON到JSON的转换。你可以通过它生成或是解析XML,甚至还可以创建合并这两者的查询。在下面这个来自于JSONiq文档的示例中,你可以看到JSONiq被用作模板语言来生成HTML表格。

类似于XQuery,JSONiq也支持重叠与非重叠窗口。该特性可用于将数据平均划分为若干块,或是用于统计计算,如计算“last 3”的平均值。可以通过XPath规范了解关于tumbling与sliding windows的更多内容

JSONiq的另一个特性就是更新JSON数据的能力。在该示例中,你可以看到一个status属性被插入到了匹配名字“Deadbeat Jim”的记录中。

JSONiq是XQuery处理器Zorba的一部分,Zorba基于Apache 2许可。JSONiq本身则基于Creative Commons Attribution-ShareAlike 3.0 Unported许可

查看英文原文:JSONiq: The JSON Query Language

译者 张龙 热衷于编程,乐于分享,对新技术有强烈的探索欲,对Java轻量级框架有一定研究。

This entry was posted in ASP.NET. Bookmark the permalink.

发表评论

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out / 更改 )

Twitter picture

You are commenting using your Twitter account. Log Out / 更改 )

Facebook photo

You are commenting using your Facebook account. Log Out / 更改 )

Google+ photo

You are commenting using your Google+ account. Log Out / 更改 )

Connecting to %s