使用 MongoDB,我将如何编写这个常规 SQL 语句?
SELECT * FROM table WHERE (field1+field2+field3) > 1
我一直在搞乱 $group、$project、$add 等。我觉得我在围绕解决方案跳舞,但无法弄清楚。
最简单的方法是使用$where http://docs.mongodb.org/manual/reference/operator/query/where/(我并不是说不可能通过聚合来做到这一点)
db.table.find({$where: function() {
return this.field1 + this.field2 + this.field3 > 1
// most probably you have to handle additional cases if some of the fields do not exist.
}}
它的优点是简单直观,缺点是:
要求数据库处理 JavaScript 表达式或
集合中每个文档的函数。
如果您需要经常执行此类搜索,我会继续创建一个新字段,其中存储 3 个字段的总和,并在其上放置一个索引。缺点是您必须增加应用程序逻辑。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)