浅谈mongodb数据库、及mongodb数据库的用法

MongoDB简介

mongodb 是一个功能最丰富的NoSQL非关系数据库。由 C++ 语言编写。 mongodb 本身提供S端存储数据,即server;也提供C端操作处理(如查询等)数据,即client

SQL和NoSQL的主要区别

1.在SQL中层级关系: 数据库>表>数据 而在NoSQL中则是: 数据库>集合>文档
2.SQL中如何需要增加外部关联数据的话,规范化做法是在原表中增加一个外键,关联外部数据表 NoSQL则可以把外部数据直接放到原数据集中,以提高查询效率。缺点也比较明显,对关联数据做更新时会比较麻烦。
3.SQL中在一个表中的每条数据的字段是固定的。而NoSQL中的一个集合(表)中的每条文档(数据)的key(字段)可以是互不相同的。

mongodb作为非关系型数据库相较于关系型数据库的优势

1.易扩展: NoSQL数据库种类繁多, 但是一个共同的特点都是去掉关系数据库的关系型特性。 数据之间无关系, 这样就非常容易扩展
2.大数据量,高性能: NoSQL数据库都具有非常高的读写性能, 尤其在大数据量下表现优秀。 这得益于它的非关系性,数据库的结构简单
3.灵活的数据模型: NoSQL无需事先为要存储的数据建立字段, 随时可以存储自定义的数据格式。 而在关系数据库中, 增删字段是一件非常麻烦的事情。 如果是非常大数据量的表, 增加字段简直就是一个噩梦

mongodb数据库的安装

请参考mongodb数据库官方文档

MongoDB使用

mongodb数据库服务端的启动配置请参考官方文档

mongodb客户端

  • 启动本地客户端: mongo
  • 查看帮助:mongo –help
  • 退出:exit或者ctrl+c

mongodb数据库的命令

  • 查看当前的数据库:db(没有切换数据库的情况下默认使用test数据库)
  • 查看所有的数据库:show dbs /show databases
  • 切换数据库:use db_name
    • db_name为show dbs后返回的数据库名
  • 删除当前的数据库:db.dropDatabase()

mongodb集合的命令

  • 无需手动创建集合: 向不存在的集合中第一次添加数据时,集合会自动被创建出来
  • 手动创建集合:
    • db.createCollection(name,options)
      
    • db.createCollection("stu")
      
    • db.createCollection("sub", { capped : true, size : 10 } )
      
    • 参数capped:默认值为false表示不设置上限,值为true表示设置上限
      
    • 参数size:集合所占用的字节数。 当capped值为true时,需要指定此参数,表示上限大小,当文档达到上限时, 会将之前的数据覆盖,单位为字节
      
  • 查看集合:show collections
  • 删除集合:db.集合名称.drop()
  • 检查集合是否设定上限: db.集合名.isCapped()

简单练习:

show dbs
use test
show collections
db
db.stu.insert({'name':'郭靖', 'age':22})
show dbs
show collections
db.stu.find()
db.stu.drop()
show collections
db.dropDatabase()
show dbs
exit

可以试着在mongo shell中执行以上命令,看看执行的结果是什么

小结:

  • 服务端的启动
    • sudo mongod --dbpath=数据库路径
  • 进入mongo shell客户端
    • mongo
  • mongodb的数据库和集合命令
    • show dbs 查看所有数据库
    • use db_name 使用某个数据库
    • show collections 查看所有集合
    • db 查看当前的数据库(没有切换数据库的情况下默认使用test数据库)
    • db.集合名.drop() 删除某个集合
    • db.dropDatabase() 删除当前的数据库
    • exit 退出客户端

mongodb数据库数据的增删改查

插入数据

  • 命令:db.集合名称.insert(document)
  • db.stu.insert({name:‘gj’, gender:1})
  • db.stu.insert({_id:“20170101”, name:‘gj’, gender:1})

注:插文档时,如果不指定_id参数,MongoDB会为文档自动分配一个唯一的ObjectId

保存数据

  • 命令:db.集合名称.save(document)
  • db.stu.save({_id:‘20170101’, name:‘gj’, gender:2})
  • db.stu.save({name:‘gj’, gender:2})
  • db.stu.find()

注:如果文档的_id已经存在则修改,如果_id不存在则添加

查询数据

  • 命令:db.集合名称.find()

用以下数据进行测试

db.stu.insert({"name" : "郭靖", "hometown" : "蒙古", "age" : 20, "gender" : true })
db.stu.insert({"name" : "黄蓉", "hometown" : "桃花岛", "age" : 18, "gender" : false })
db.stu.insert({"name" : "华筝", "hometown" : "蒙古", "age" : 18, "gender" : false })
db.stu.insert({"name" : "黄药师", "hometown" : "桃花岛", "age" : 40, "gender" : true })
db.stu.insert({"name" : "段誉", "hometown" : "大理", "age" : 16, "gender" : true })
db.stu.insert({"name" : "段王爷", "hometown" : "大理", "age" : 45, "gender" : true })
db.stu.insert({"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]}})
      
支持正则表达式

使用$regex编写正则表达式

  • 查询name以’黄’开头的数据
    • db.stu.find({name:{$regex:'^黄'}})
      
自定义查询

mongo shell 是一个js的执行环境 使用$where 写一个函数, 返回满足条件的数据

  • 查询年龄大于30的学生
    • db.stu.find({$where:function() {return this.age>30;}})
      
skip和limit
  • 方法limit(): 用于读取指定数量的文档
  • db.集合名称.find().limit(NUMBER)
  • 查询2条学生信息
  • db.stu.find().limit(2)
  • 方法skip(): 用于跳过指定数量的⽂档
  • db.集合名称.find().skip(NUMBER)
  • db.stu.find().skip(2)
  • 同时使用
  • db.stu.find().limit(4).skip(5)
  • db.stu.find().skip(5).limit(4)
    注意:先使用skip在使用limit的效率要高于前者
投影

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

  • 命令:db.集合名称.find({},{字段名称:1,…})

参数为字段与值, 值为1表示显示, 值为0不显 特别注意:

  • 对于_id列默认是显示的, 如果不显示需要明确设置为0
  • 对于其他不显示的字段不能设置为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.stu.find({gender:true}).count()
    
  • 命令:db.集合名称.count({条件})
  • db.stu.count({age:{$gt:20},gender:true})
    
mongodb的更新

db.集合名称.update({query}, {update}, {multi: boolean})

  • 参数query:查询条件
  • 参数update:更新操作符
  • 参数multi:可选,默认是false,表示只更新找到的第一条数据,值为true表示把满足条件的数据全部更新
  • db.stu.update({name:‘hr’},{name:‘mnc’}) # 全文档进行覆盖更新
  • db.stu.update({name:‘hr’},{$set:{name:‘hys’}}) # 指定键值更新操作 如果符合条件的有多个更新最近的一个
  • db.stu.update({},{$set:{gender:0}},{multi:true}) # 更新全部

注:multi参数必须和$set一起使用!

mongodb的删除

db.集合名称.remove({query}, {justOne: boolean})

  • 参数query:可选,删除的⽂档的条件
  • 参数justOne:可选, 如果设为true或1,则只删除一条,默认false,表示删除全部
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值