mongodb增删改查
(一)增:
创新互联公司是一家业务范围包括IDC托管业务,虚拟空间、主机租用、主机托管,四川、重庆、广东电信服务器租用,成都移动服务器托管,成都网通服务器托管,成都服务器租用,业务范围遍及中国大陆、港澳台以及欧美等多个国家及地区的互联网数据服务公司。
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'}});
文章标题:mongodb增删改查
文章起源:http://ybzwz.com/article/poggoc.html