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://scyanting.com/article/poggoc.html