是否有(大致)SQL或类似xquery的语言来查询JSON?
我正在考虑非常小的数据集,很好地映射到JSON,它将很容易回答查询,如“X的所有值是什么,Y > 3”或做通常的SUM / COUNT类型操作。
作为一个完全虚构的例子,是这样的:
[{"x": 2, "y": 0}}, {"x": 3, "y": 1}, {"x": 4, "y": 1}]
SUM(X) WHERE Y > 0 (would equate to 7)
LIST(X) WHERE Y > 0 (would equate to [3,4])
我认为这将在客户端和服务器端工作,结果将被转换为适当的特定于语言的数据结构(或者可能保留为JSON)
快速搜索一下谷歌,就会发现人们已经考虑过它并实现了一些东西(JAQL),但它似乎还没有一个标准的用法或库集出现。虽然单独实现每个功能都是相当琐碎的,但如果有人已经做对了,我就不想重新发明轮子。
有什么建议吗?
Edit: This may indeed be a bad idea or JSON may be too generic a format for what I'm thinking.. The reason for wanting a query language instead of just doing the summing/etc functions directly as needed is that I hope to build the queries dynamically based on user-input. Kinda like the argument that "we don't need SQL, we can just write the functions we need". Eventually that either gets out of hand or you end up writing your own version of SQL as you push it further and further. (Okay, I know that is a bit of a silly argument, but you get the idea..)
在MongoDB中,这就是它的工作方式(在mongo shell中,存在您选择的语言的驱动程序)。
db.collection.insert({"x": 2, "y": 0}); // notice the ':' instead of ','
db.collection.insert({"x": 3, "y": 1});
db.collection.insert({"x": 4, "y": 1});
db.collection.aggregate([{$match: {"y": {$gt: 0}}},
{$group: {_id: "sum", sum: {$sum: "$x"}}}]);
db.collection.aggregate([{$match: {"y": {$gt: 0}}},
{$group: {_id: "list", list: {$push: "$x"}}}]);
前三个命令将数据插入到集合中。(只需启动mongod服务器并连接mongo客户端。)
接下来的两个处理数据。$match过滤,$group分别应用sum和list。
我刚刚完成了一个客户端JS-lib (defy .js)的可发布版本,它可以满足您的需求。使用defy .js,您可以使用您熟悉的XPath表达式(没有像JSONPath中那样的新语法表达式)查询JSON结构。
它如何工作的例子(在浏览器这里http://defiantjs.com/defiant.js/demo/sum.avg.htm):看到它
var data = [
{ "x": 2, "y": 0 },
{ "x": 3, "y": 1 },
{ "x": 4, "y": 1 },
{ "x": 2, "y": 1 }
],
res = JSON.search( data, '//*[ y > 0 ]' );
console.log( res.sum('x') );
// 9
console.log( res.avg('x') );
// 3
console.log( res.min('x') );
// 2
console.log( res.max('x') );
// 4
如您所见,defantjs使用搜索函数扩展了全局对象JSON,返回的数组使用聚合函数交付。defantjs包含一些其他功能,但这些超出了本主题的范围。
无论如何,您都可以使用客户端XPath评估器测试库。我认为不熟悉XPath的人会发现这个求值器很有用。
http://defiantjs.com/#xpath_evaluator
更多关于defy .js的信息
http://defiantjs.com/
https://github.com/hbi99/defiant.js
我希望它对你有用……
问候
谷歌有一个项目叫lovefield;刚刚发现了它,它看起来很有趣,尽管它比键入下划线或lodash更复杂。
https://github.com/google/lovefield
Lovefield是一个用纯JavaScript编写的关系查询引擎。它
还提供了在浏览器端持久化数据的帮助。
使用IndexedDB本地存储数据。它提供了类似sql的语法和
跨浏览器工作(目前支持Chrome 37+, Firefox 31+, IE
10+, Safari 5.1+…
这个领域最近出现的另一个有趣的条目叫做jinqJs。
http://www.jinqjs.com/
简单回顾一下示例,它看起来很有前途,API文档似乎写得很好。
function isChild(row) {
return (row.Age < 18 ? 'Yes' : 'No');
}
var people = [
{Name: 'Jane', Age: 20, Location: 'Smithtown'},
{Name: 'Ken', Age: 57, Location: 'Islip'},
{Name: 'Tom', Age: 10, Location: 'Islip'}
];
var result = new jinqJs()
.from(people)
.orderBy('Age')
.select([{field: 'Name'},
{field: 'Age', text: 'Your Age'},
{text: 'Is Child', value: isChild}]);
jinqJs is a small, simple, lightweight and extensible javaScript
library that has no dependencies. jinqJs provides a simple way to
perform SQL like queries on javaScript arrays, collections and web
services that return a JSON response. jinqJs is similar to Microsoft's
Lambda expression for .Net, and it provides similar capabilities to
query collections using a SQL like syntax and predicate functionality.
jinqJs’s purpose is to provide a SQL like experience to programmers
familiar with LINQ queries.
jq是一种JSON查询语言,主要用于命令行,但绑定到广泛的编程语言(Java, node.js, php,…),甚至可以通过jq-web在浏览器中使用。基于c语言的jq实现通常被称为“jq”,基于go语言的版本被称为“gojq”。
以下是基于原始问题的一些插图,以JSON为例:
[{"x": 2, "y": 0}}, {"x": 3, "y": 1}, {"x": 4, "y": 1}]
SUM(X) WHERE Y > 0(等于7)
map(select(.y > 0)) | add
LIST(X) WHERE Y > 0(等于[3,4])
map(.y > 0)
jq语法扩展了JSON语法
每个JSON表达式都是一个有效的jq表达式,像[1,(1+1)]和{"a":(1+1)} '这样的表达式说明了jq如何扩展JSON语法。
一个更有用的例子是jq表达式:
{a,b}
,考虑到JSON值{“a”:1、“b”:2,“c”:3},等于{“a”:1、“b”:2}。