千家信息网

mongodb 增删改查

发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,(一)增:db.collname.insert({name:"user1",age:"20"}) 添加一条常规数据,添加的数字是以json格式的键值对,后面的值需要添加双引号或引号db.collnam
千家信息网最后更新 2025年02月01日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:[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'}});

0