db.集合名称.insert(document)
db.stu.insert({name:'gj', gender:1}) #单条插入 db.stu.insert({name:'gj', gender:1},{name:'gj', gender:1},{name:'gj', gender:2},......) #批量插入 db.stu.insert({_id:"20170101", name:'gj', gender:1})#带有id的集合数据
命令:db.集合名称.save(document)
,如果文档的_id已经存在则修改,如果_id不存在则添加,这种修改的方式是根据id进行修改,不是特别好,后面有替代的方案。
db.stu.save({_id:'20170101', name:'gj', gender:2})#如果找到了当前id做修改数据操作,如果找不到当前的id则随机生成id插入数据 db.stu.save({name:'gj', gender:2}) db.stu.find()#查询该集合中所有的数据
命令:db.集合名称.find()
可以使用以下数据进行练习:
db.stu.insert([{"name" : "郭靖", "hometown" : "蒙古", "age" : 20, "gender" : true }, {"name" : "黄蓉", "hometown" : "桃花岛", "age" : 18, "gender" : false }, {"name" : "华筝", "hometown" : "蒙古", "age" : 18, "gender" : false }, {"name" : "黄药师", "hometown" : "桃花岛", "age" : 40, "gender" : true }, {"name" : "段誉", "hometown" : "大理", "age" : 16, "gender" : true }, {"name" : "段王爷", "hometown" : "大理", "age" : 45, "gender" : true }, {"name" : "洪七公", "hometown" : "华筝", "age" : 18, "gender" : true }])
方法find(): 查询
db.集合名称.find({条件文档})
方法findOne():查询,只返回第一个
db.集合名称.findOne({条件文档})
方法pretty(): 将结果格式化;不能和findOne()一起使用!
db.集合名称.find({条件文档}).pretty()
$lt (less than)
$lte (less than equal)
$gt (greater than)
$gte
$ne
查询年龄大于18的所有学生 db.stu.find({age:{$gte:18}})
and:在json中写多个条件即可
查询年龄大于或等于18, 并且性别为true的学生 db.stu.find({age:{$gte:18},gender:true})
or:使用$or, 值为数组, 数组中每个元素为json
查询年龄大于18, 或性别为false的学生 db.stu.find({$or:[{age:{$gt:18}},{gender:false}]}) 查询年龄大于18或性别为男生, 并且姓名是郭靖 db.stu.find({$or:[{age:{$gte:18}},{gender:true}],name:'gj'})
$in
, $nin
判断数据是否在某个数组内查询年龄为18、 28的学生 db.stu.find({age:{$in:[18,28,38]}})
查询name以'黄'开头的数据 db.stu.find({name:{$regex:'^黄'}})
mongo shell 是一个js的执行环境,使用$where 写一个函数, 返回满足条件的数据
查询年龄大于30的学生 db.stu.find({ $where:function() { return this.age>30;} })
方法limit(): 用于读取指定数量的文档
db.集合名称.find().limit(NUMBER) 查询2条学生信息 db.stu.find().limit(2)
方法skip(): 用于跳过指定数量的⽂档
db.集合名称.find().skip(NUMBER) db.stu.find().skip(2)
同时使用,注意:先使用skip在使用limit的效率要高于前者
db.stu.find().limit(4).skip(5) db.stu.find().skip(5).limit(4)
命令:db.集合名称.find({},{字段名称:1,...})
参数为字段与值, 值为1表示显示, 值为0不显
特别注意:
db.stu.find({},{_id:0,name:1,gender:1})
方法sort(), 用于对查询结果按照指定的字段进行排序
命令:db.集合名称.find().sort({字段:1,...})
参数1为升序排列
参数-1为降序排列
根据性别降序, 再根据年龄升序 db.stu.find().sort({gender:-1,age:1})
方法count()用于统计结果集中文档条数
命令:db.集合名称.find({条件}).count()
命令:db.集合名称.count({条件})
db.stu.find({gender:true}).count() db.stu.count({age:{$gt:20},gender:true})
方法:distinct()
命令:db.集合名称.distinct({去重条件})
db.stu.distinct({去重条件}) db.stu.distinct({去重条件},{查询条件})
db.集合名称.update({query}, {update}, {multi: boolean})
db.stu.update({name:'hr'},{name:'mnc'}) # 全文档进行覆盖更新,单条 db.stu.update({name:'hr'},{$set:{name:'hys'}}) # 指定键值更新操作,查询到的第一条 db.stu.update({},{$set:{gender:0}},{multi:true}) # 更新全部,查询到的全部,插入新的字段 db.stu.update({"查询条件"},{$set"{age:100},{upsert rue}) #查找到就更新,查找不到就新增
注意:"multi update only works with $ operators",multi参数必须和$set一起使用!
db.集合名称.remove({query}, {justOne: boolean})