首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我能在mongo db查询中解析JSON吗?

我能在mongo db查询中解析JSON吗?
EN

Stack Overflow用户
提问于 2021-06-28 00:12:00
回答 1查看 35关注 0票数 1

假设我的集合中有以下文档

代码语言:javascript
复制
{'name':'toothpaste','price':'{"currency":"USD","value":17}'}
{'name':'laptop','price':'{"currency":"EUR","value":1080}'}

我想一次查询单据,单据的价格币种是USD,价格值小于100。请记住,价格列n包含一个JSON字符串,而不是嵌入式对象

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-28 00:49:01

要在查询中使用自定义函数,请查看$function operator of the aggregation framework。这是Mongo >= 4.4的一个新特性(感谢@Victor)

至于您的查询,您可以这样做:

代码语言:javascript
复制
db.items.find({"$expr": { "$function": {
  body: function(price) {
    const parsed = JSON.parse(price);
    return parsed.currency === "USD" && parsed.value <= 100
  },
  args: ["$price"],
  lang: "js"
}  }})

我发现的一件事是,为了让JSON.parse()正确工作,必须用双引号保存JSON字符串(您这样做是正确的

使用mongo Web shell here测试代码

代码语言:javascript
复制
>>> db.items.insertMany([ { "name": "toothpaste", "price": '{"currency":"USD","value":17}' }, { "name": "laptop", "price": '{"currency":"EUR","value":1080}' } ])

>>> db.items.find({"$expr": { "$function": {
  body: function(price) {
    const parsed = JSON.parse(price);
    return parsed.value === 17
  },
  args: ["$price"],
  lang: "js"
}  }})
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68153068

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档