MongoDB逻辑与操作

来源:未知 责任编辑:责任编辑 发表时间:2013-12-22 14:56 点击:

看下面两个例子 

rs1:PRIMARY> db.display.find({$and: [{$where: '(1386813645 - this.last_active_time > 300)'}, {status: "online"}]}).count()
0
rs1:PRIMARY> db.display.find({$where: '(1386813645 - this.last_active_time > 300)'}, {status: "online"}).count()
0

第二个和第一个等价,是一个隐式的逻辑与操作。一直以来,只有第二中形式,可能是为了更完整吧,2.0之后,MongoDB引入了第一种形式。

 参考文档:http://docs.mongodb.org/manual/reference/operator/query/and/

在文档中,还提到了另一种使用方法,就是对一个字段执行逻辑与操作的时候,可以简写为如下形式:

 db.inventory.update( { price: { $ne: 1.99, $exists: true } } , { $set: { qty: 15 } } )

只有当price 不等于1.99,并且存在时,才更新qty为15. 

所以,我的结论是一般用隐式就好,写起来简单方便。

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • db2管理工具小结
    • DB2数据库的导出与导入(Windows客户端)
    • db2 CLP中如何换行
    • DB2查看表结构及所用表语句
    • DB2 · CREATE TABLESPACE
    • 使用DB2对象:创建模式、表和视图
    • DB2数据库逻辑卷的复制
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1