我们将 User
数据存储到 MongoDB 中。客户端提供一个 JSONPath 查询来请求过滤的用户集。
例如:
$.users[@.salary > 10000]
是一个 JSONPath 查询,用于检索薪水大于 10000 的用户。
数据:
"users": [ {
"firstName": "John",
"lastName" : "doe",
"age" : 26,
"salary" : 5000,
"address" : {
"streetAddress": "naist street",
"city" : "Nara",
"postalCode" : "630-0192"
},
"phoneNumbers": [
{
"type" : "iPhone",
"number": "0123-4567-8888"
},
{
"type" : "home",
"number": "0123-4567-8910"
},
........
]
}
然而,同样的 MongoQuery 将是:
db.inventory.find( { salary: { $gt: 10000 } })
我们有连接到 MongoDB 的 Java 应用程序代码。
有什么方法可以直接运行这个 JSONPath 查询到 MongoDB 吗?
使用 Mongo 查询意味着将 JSONPath 查询转换为 MongoQuery,这在代码中会很麻烦。一个非常暴力的方法是首先在 AS(应用程序)上获取所有用户,然后将 List<Document>
转换为 Json 字符串,然后运行 JSONPath 查询。
任何帮助将不胜感激。
最佳答案
现阶段无法立即执行此操作 - 请参阅此开放请求:https://jira.mongodb.org/browse/SERVER-736
我个人建议您采用某种翻译方法 - 这是我看到的唯一可行的选择,除了无法扩展的蛮力客户端评估(但对于小型数据集可能非常好) )。另外,翻译查询所需的代码可以很好地进行单元测试,因此它应该是一个相当安全的选择。
这里有一些关于从哪里获取/建立所需翻译代码的想法。
基于正则表达式和解析(专门针对 MongoDB):https://github.com/gabrielelana/mongodb-shell-extensions/blob/master/src/jsonpath.js
或者,这可能用于将 JSONPath 字符串解析为对象模型,然后您可以将其转换为 MongoDB 查询:https://github.com/json-path/JsonPath
关于MongoDB 上的 JSONPath 查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51208467/