你好,游客 登录 注册 搜索
背景:
阅读新闻

MongoDB 可读性比较差的语句

[日期:2012-12-10] 来源:Linux社区  作者:puncha [字体: ]

今天学习update语句,和$push修改器,书上举得例子让我百思不得其解,update()的前两个参数分别是:查询,新文档。书上的例子如下所示,在集合里面找Key是Gende不是Mr的项,找到之后,把他的Gender设置为M。按照我的想法,谁都没有Gendar属性,那么条件不满足,后面的新文档就不会生成咯,但是执行的结果却大相径庭,因为所有文档都没有Gender属性,所以第一条文档被返回了,而Gender属性也加到了第一条文档during上!

> db.test.remove() 

> db.test.insert( {"name" : "during"} ) 
> db.test.insert( {"name" : "puncha"} ) 

> db.test.find() 
{ "_id" : ObjectId("50c21581810234135d194bcc"), "name" : "during" } 
{ "_id" : ObjectId("50c21586810234135d194bcd"), "name" : "puncha" } 

> db.test.update( {"Gender" : {"$ne":"M"}},{"$push": {"Gender" : "M"}} ) 

> db.test.find() 
{ "_id" : ObjectId("50c21586810234135d194bcd"), "name" : "puncha" } 
{ "Gender" : [ "M" ], "_id" : ObjectId("50c21581810234135d194bcc"), "name" : "du 
ring" } 

linux
相关资讯       MongoDB教程  MongoDB update 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款