设为首页 收藏本站
查看: 1701|回复: 0

[经验分享] mongodb 增删改查

[复制链接]

尚未签到

发表于 2018-10-27 12:20:26 | 显示全部楼层 |阅读模式
  (一)增:
  db.collname.insert({name:"user1",age:"20"})  添加一条常规数据,
  添加的数字是以json格式的键值对,后面的值需要添加双引号或引号
  db.collname.insert({time:new Date()})   mongodb支持js,可以在query中添加js语句
  db.collname.insert({name:["user1","user2","user3"]}); 添加一条有数组的数据
  db.collname.insert({name:{first:"user1",middle :"user2",last:"user3"}}) 添加一条有内嵌            文档的数据,(mongodb中一行数据也称为文档(document))
  自定义文档插入:
  > doc={
  ... name:"user",
  ... age:"20",
  ... sexy:"man"
  ... }
  { "name" : "user", "age" : "20", "sexy" : "man" }
  > db.c1.insert(doc);
  (二)查
  查看collection(c1)所有的数据
  db.c1.find()
  查看用户名为smith的数据
  db.c1.find(name:"smith")
  查看除了age字段以外的所有数据
  db.c1.find({},{age:0})
  查看用户名为smith,不包括age字段的其他字段
  db.c1.find({name:"smith"},{age:0})
  只查看用户名为smith的age字段
  db.c1.find({name:"smith"},{age:1})
  查看年龄大于20的数据
  db.c1.find({age:{ $gt:20 }})
  查看年龄小于20的数据
  db.c1.find({age:{ $lt:20 }})
  查看年龄大于等于20的数据
  db.c1.find({age:{ $gte:20 }})
  查看年龄小于等于20的数据
  db.c1.find({age:{ $lte:20 }})
  查看年龄不等于20的数据
  db.c1.find({age:{ $ne:20 }})
  查看同时有singging和football爱好的数据
  db.c1.find({hobby:{$all:[”singging",“football”]}});($all 必须都包括,$in只需要包            括其 中一个)
  查看有singging或是football爱好的数据
  db.c1.find({hobby:{$in:[”singging",“football”]}})
  查看没有singging或是football爱好的数据
  db.c1.find({hobby:{$nin:[”singging",“football”]}})
  查看存在某个字段的数据:并只输出五条数据
  db.c1.find({name:{$exists:true }}).limit(5);
  取模操作,查看年龄尾数为一的数据
  db.c1.find({age:{$mod:[10,1]}});
  查看符合至少一个要求的数据 $or
  db.c1.find({$or:[{age:20},{sexy:"man"});
  查看一个要求都不符合的数据 $nor
  db.c1.find({$nor:[{age:20},{sexy:"man"});
  查看数组长度等于3的数据(设a为数组)
  db.c1.find({a:{$size:3}})
  检索name属性是以u开头,4结尾的所有用户(可使用正则表达式)
  db.c1.find({name:/u.*4$/i})
  排序//1表示升序,-1表示降序
  db.c1.find().sort({_id: 1})
  查下唯一值
  db.c1.distinct(“age")
  分页查询:
  db.c1.find().skip(20).limit(8);
  或是:db.c1.find({},{},8,20);
  查询记录数:
  db.c1.find().count();
  查询某document没有数值,或不存在:
  db.c1.find(name:null)
  查询中$slice的用法
  db.posts.find({}, {comments:{$slice: 5}}) // 前5条评论
  db.posts.find({}, {comments:{$slice: -5}}) //后5条评论
  db.posts.find({}, {comments:{$slice: [20, 10]}}) // skip 20, limit 10
  db.posts.find({}, {comments:{$slice: [-20, 10]}}) // 20 from end, limit 10
  (三)删
  删除c1(collection)下的所有数据
  db.c1.remove()
  删除id为10的数据
  db.c1.remove({_id:10})
  建议:删除操作的时候,尽量用_id作为条件
  某些情况下,当你在对一个记录执行remove操作的时候,可能会有update操作在这个记录上,这样就可能删除不掉这个记录,如果你觉得这不尽人意,那么你可以在remove操作的时候加上$atomic:         db.videos.remove( { rating : { $lt : 3.0 }, $atomic : true } )
  (四)改
  语法 db.collection.update( criteria, objNew, upsert, multi )
  Criteria:用于设置查询条件的对象
  Objnew:用于设置更新内容的对象
  Upsert:如果记录已经存在,更新它,否则新增一个记录
  Multi:如果有多个符合条件的记录,全部更新
  注意:默认情况下,只会更新第一个符合条件的记录
  如果存在更新它,如果不存在,新增记录  db.mycollection.save(x);
  把id为0的age改成20
  db.user.update({_id:0},{$set:{age:20}});
  把id为0的age加上20
  db.user.update({_id:0},{$inc:{age:20}});
  把id为0的age减去20
  db.user.update({_id:0},{$inc:{age:-20}});
  把id为0的sex字段删除
  db.user.update({_id:0},{$unset:{sex:1}});
  修改id为0的hobby字段(前提hobby是数组,或是不存在,否则会报错)
  db.user.update({_id:0},{$push:{hobby:'football'}});
  { $pushAll : { field : value_array } } 用法跟上面一样
  往id为0的hobby字段添加一个数据(前提hobby是数组,或是不存在,否则会报错)
  db.user.update({_id:0},{$addToSet:{hobby:'football'}});
  删除id为0的hobby字段的最后一个数据(前提hobby是数组,或是不存在,否则会报错
  db.user.update({_id:0},{$pop:{hobby:'football'}});
  删除id为0的hobby字段中符合条件的数据(前提hobby是数组,或是不存在,否则会报错
  db.user.update({_id:0},{$pull:{aihao:'bike'}});
  把id为0的数据中name字段名改为username
  db.user.update({_id:0},{$rename:{'name':'username'}});


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-627123-1-1.html 上篇帖子: mongodb的简单操作 下篇帖子: mongodb 系统性能篇(1)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表