Mongodb数据库的增删改查(三)

Mongodb的增删改查

7.1mongodb插入数据
  • 命令:db.集合名称.insert(document)

    db.stu.insert({name:'wtt',gender:1})
    db.stu.insert({_id:"20200109",name:'wtt',gender:1})
    

    插入文档时,如果不指定_id参数,MongDB为会文档自动分配一个唯一的ObjectID

7.2mongodb保存数据
  • 命令:db.集合名称.save(document)

    db.stu.save({_id:'20200109',name:'wt',gender:2})
    db.stu.save({name:'wt',gender:20})
    db.stu.find()
    

    save后会寻找_id的数据,如果有,则查看内容是否相同,相同的话不做操作,不同的话则做更新。如果没有找到_id的数据则进行插入操作。

7.3mongodb的查询
  • 命令:db.集合名称.find()

7.3.1 简单查询

  • 方法find():查询
    • db.集合名称.find({条件文档})
  • 方法findOne():查询,只返回第一个
    • db.集合名称.findOne({条件文档})
  • 方法pretty():将结果格式化;不能和findOne()一起使用
    • db.集合名称.find({条件文档}).pretty()

7.3.2 比较运算符

  • 等于:默认是等于判断,没有运算发

  • 小于:$lt

  • 小于等于:$lte

  • 大于:$gt

  • 大于等于:$gte

  • 不等于:$ne

    查询年龄大于18的所有学生

db.stu.find({age:{$gte:18}})

7.3.3 逻辑运算符

  • 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:'wtt'})
    

7.3.4 范围运算符

  • 使用$in , $nin 判断数据是否在某个数组内
# 查询年龄为18、28的学生
db.stu.find({age:{$in:[18,28,38]}})

7.3.5 支持正则表达式

  • 使用$regex编写正则表达式
#查询name以"黄"开头的数据
db.stu.find({name:{$regex:"^黄"}})

7.3.6 自定义查询

  • mongo shell 是一个js的执行环境
  • 使用$where写一个函数,返回满足条件的数据
#查询年龄大于30的学生
db.stu.find({
    $where:function(){
        return this.age>30;}
})

7.3.7 skip和limit

  • 方法limit():用于读取指定数量的文档
db.集合名称.find().limit(Number)
# 查询2条学生信息
db.stu.find().limit(2)
  • 方法skip():用于跳过指定数量的文档
db.集合名称.skip(Number)
db.stu.find().skip(2)
  • 同时使用 skip优先级比limit高
db.stu.find().skip(2).limit(3)

7.3.8 投影

在查询到的返回结果中,只选择必要的字段

  • 命令:db.集合名称.find({},{字段名称:1,…}})
    • 参数为字段与值,值为1表示显示,值为0不显示
    • 注意:
      • 对于_id列默认是显示的,如果不显示需要明确设置为0
      • 对于其他不显示的字段不能设置为0
db.stu.find({},{_id:0,name:1,gender:1})

7.3.9 排序

方法sort(),用于对查询结果按照指定的字段进行排序

  • 命令:db.集合名称.find().sort({字段:1,…})
    • 参数1为升序排列,参数-1为降序排序
# 根据性别降序,再根据年龄升序
db.stu.find().sort({gender:-1,age:1})

7.3.10 统计个数

方法count(),用于统计结果集中文档条数

  • 命令:db.集合名称.find({条件}).count()
  • 命令:db.集合名称.count({条件})
db.stu.find({gender:true}).count()
db.stu.count({age:{$gt:20},gender:true})

7.3.11 去重

方法distinct(),用于去重

  • db.集合名称.distinct()
db.stu.distinct("name") # 对字段去重
db.stu.distinct("name",{age:18})  #对name字段以{age:18}为条件去重 
db.stu.distinct({age:18})  # 直接对age是18的人进行去重

7.4 mongodb的更新

  • db.集合名称.update( {query}, {update}, {multi:boolean},{upsert:bollean} )
    • 参数query:查询条件 找到符合条件的数据
    • 参数update:更新操作符 要更新什么
    • 参数multi:可选,默认是false,表示只更新找到的第一条数据,值为true表示把满族的条件数据全部更新
    • 参数upsert:可选,如果为true则查询不到符合条件的数据后进行新增这条数据
# 全文档进行覆盖更新
db.stu.update({name:'hr'},{name:'mnc'})
# 指定键值更新操作
db.stu.update({name:'hr'},{$set:{name:'aaa'}})
# 更新全部
db.stu.update({},{$set:{gender:0}},{multi:true})
# upsert
db.stu.update({name:'waa'},{$set:{gender:2}},{upsert:true})
  • 注意:“multi update only works with $ operators”
    • multi参数必须和$set一起使用!

7.5 mongodb的删除

  • db.集合名称.remove( {query}, {justOne: boolean} )
    • 参数query:可选,删除的文档的条件
    • 参数justOne:可选,如果设为true或1,则只删除一条,默认为false,表示删除所有

你可能感兴趣的:(mongodb)