5290589 发表于 2018-10-27 12:20:26

mongodb 增删改查

  (一)增:
  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:}});
  查看符合至少一个要求的数据 $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: }}) // 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]
查看完整版本: mongodb 增删改查