MongoDB数据库

1、mongodb数据库(典型的非关系型数据库)

  • 数据库的导入:关系型和非关系型数据库

    常见的数据库:

    • 关系型数据库概念:关系型数据库 以行(记录)和列(字段)的形式存储数据,以便于用户理解。这一系列的行和列被称为表(关系),一组表组成了数据库。表与表之间的数据记录有关系。
    • 关系型数据库:Access mySql SqlServer oracle db2等。
    • 非关系型数据库概念:非关系型数据库以文档(键值对的一个集合)的形式存储数据。这一系列的文档被称为集合,一系列集合组成了数据库。
    • 非关系型数据库:MongoDB,Redis,HBase,CouchDB等。

    ps:文档型数据这个名字中,“文档”两个字很容易误解。其实这个文档就是 bson 。bson 是 json 的超集,比如 json 中没法储存二进制类型,而 bson 拓展了类型,提供了二进制支持。mongodb 中存储的一条条记录都可以用 bson 来表示。所以你也可以认为,mongodb 是个存 bson 数据的数据库。

  • 非关系型数据库与关系型数据库区别

    • 非关系型数据库的优势:

      \1. 性能

      NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL层的解析,所以性能非常高。

      \2. 可扩展性

      同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展。

    • 关系型数据库的优势:

      \1. 复杂查询

      可以用SQL语句方便的在多个表之间做非常复杂的数据查询。

      \2. 事务支持

      使得对于安全性能很高的数据访问要求得以实现。

  • mongodb

    • MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。

    • MongoDB优点:高性能、易部署、易使用,存储数据非常方便。

      • 面向集合存储,易存储对象类型的数据。
      • 模式自由。
      • 支持动态查询。
      • 支持完全索引,包含内部对象。
      • 支持查询。
      • 支持复制和故障恢复。
      • 使用高效的二进制数据存储,包括大型对象(如视频等)。
      • 自动处理碎片,以支持云计算层次的扩展性
      • 支持RUBY,PYTHON,JAVA,C++,PHP等多种语言。
      • 文件存储格式为BSON(一种JSON的扩展)
    • bson

      • BSON是一种类似json的二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌的文档对象和数组对象,但是BSON有JSON没有的一些数据类型,如Date和BinData类型。

      • BSON可以做为网络数据交换的一种存储形式,这个有点类似于Google的Protocol Buffer,但是BSON是一种schema-less的存储形式,它的优点是灵活性高,但它的缺点是空间利用率不是很理想。

        BSON有三个特点:轻量性、可遍历性、高效性。

2、mongodb常用的命令

  • Help 查看帮助

  • show dbs 显示数据库列表

  • use dbname 创建数据库

    如果数据库不存在,则创建数据库dbname,否则切换到指定数据库dbname。创建的数据库并不在数据库的列表中,要显示它,我们需要向数据库dbname插入一些数据

  • show collections 显示数据库中的集合

  • db.web.save({“name”:“老李”}) 创建了名为web的集合,并新增了一条{“name”:“老李”} 的数据

  • db.web.insert({“name”:“ghost”, “age”:10}) 在web集合中插入一条新数据,如果没有web这个集合,mongodb会自动创建

    save()和insert()也存在着些许区别:若新增的数据主键已经存在,insert()会不做操作并提示错误,而save() 则更改原来的内容为新内容。

  • db.users.remove({}) 删除users集合下所有数据

  • db.users.remove({“name”: “lecaf”}) 删除users集合下name=”lecaf”的数据

  • db.users.drop()或db.runCommand({“drop”:“users”}) 删除集合users

  • db.runCommand({“dropDatabase”: 1}) 删除当前数据库,注意 此处的1没加双引号。

  • db.users.find() 查找users集合中所有数据

  • db.users.findOne() 查找users集合中的第一条数据

  • db.users.find().pretty() 格式化查询到的数据

  • db.web.update({“name”:“a1”}, {$set: {sex:”women”}},true,true) 修改name=a1的数据为sex=1,第一个参数是查找条件,第二个参数是修改内容主键不能修改,第三个参数表示匹配所有符合条件的数据,第四个参数表示修改所有匹配到的数据

  • db.collection.find({ “key” : value }) 查找key=value的数据

  • db.collection.find({ “key” : { $gt: value } }) key > value

  • db.collection.find({ “key” : { $lt: value } }) key < value

  • db.collection.find({ “key” : { $gte: value } }) key >= value

  • db.collection.find({ “key” : { $lte: value } }) key <= value

  • db.collection.find({ “key” : { $gt: value1 , $lt: value2 } }) value1 < key <value2

  • db.collection.find().sort({ “key1” : -1 ,“key2” : 1 }) 这里的1代表升序,-1代表降序

  • db.collection.find().limit(5) 控制返回结果数量,如果参数是0,则没有约束,limit()将不起作用

  • db.collection.find().skip(5) 控制返回结果跳过多少数量,如果参数是0,则当作没有约束,skip()将不起作用,或者说跳过了0条

  • db.collection.find().skip(5).limit(5) 可用来做分页,跳过5条数据再取5条数据

  • db.collection.find().count() count()返回结果集的条数

  • db.collection.find().skip(5).limit(5).count(true) 在加入skip()和limit()这两个操作时,要获得实际返回的结果数,需要一个参数true,否则返回的是符合查询条件的结果总数

  • db.collection.find({“name”:/ab/}) 模糊查询。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值