数据库

作用:存储数据
  数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据库技术得到了更加快速的发展,应用得更加广泛。主要用它进行管理各种系统的数据,作为科学研究和决策的重要技术手段。

常见的数据库2019年排行:

mongodb数据库 套壳 mongodb数据库表_MongoDB

关系型数据库 (sql):

  • Access mySql SqlServer oracle db2等。

什么是关系型数据库?
关系型数据库 以行和列的形式存储数据,以便于用户理解。这一系列的行和列被称为表,一组表组成了数据库。表与表之间的数据记录有关系。

非关系型数据库( NoSql ):

  • MongoDB,Redis,HBase,CouchDB等。

  文档型数据这个名字中,“文档”两个字很容易误解。其实这个文档就是 bson 。bson 是 json 的超集,比如 json 中没法储存二进制类型,而 bson 拓展了类型,提供了二进制支持。mongodb 中存储的一条条记录都可以用 bson 来表示。所以你也可以认为,mongodb 是个存 bson 数据的数据库。
  数据库是一门学科,专门做数据库运维的人叫Database Administrator,简称DBA,有的DBA指深入专研一种数据库。

NoSQL简介

  NoSQL,指的是非关系型的数据库。NoSQL有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统的统称。
   NoSQL用于超大规模数据的存储。(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据)。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。

MongoDB简介

   MongoDB 是一个基于分布式 (所谓分布式就是物理上不在一起,是分开的。例如一个网页里面有html标签,该页面中加载了css样式,图片,还有视频,这些资源中,html,js,css可能在服务器A上面,图片可能在服务器B上面,视频可能在服务器c上面。)文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
   MongoDB 是非关系型数据库当中功能最丰富,最像关系型数据库的。
  随着大数据的不断发展,非关系型数据库已经变得越来越重要,相关的产品也都得到了飞速发展。而其中MongoDB更是佼佼者,作为高性能开源文档数据库,MongoDB以敏捷、可扩展和对企业应用友好而著称,因其操作简单、完全免费、源码公开等特点,受到了IT从业人员的青睐,并被广泛部署于实际的生产环境中。
  使用MongoDB的公司包括:BAT、360、Foursquare、Craiglist,、迪士尼、SAP、Intuit、EA等。
  很多大公司在用,并且越来越多的公司也要用,我们以后就可能接触到相关的项目,虽然数据库是后端人员做的事情,但是做为高级前端,有必要对它有所了解,才更好的和后端开发人员合作,做到知己知彼,百战不殆。


MongoDB优点

它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:

  • 面向集合存储,易存储对象类型的数据。
  • 模式自由。
  • 支持动态查询
  • 支持完全索引,包含内部对象
  • 支持查询
  • 支持复制和故障恢复。
  • 使用高效的二进制数据存储,包括大型对象(如视频等)。
  • 自动处理碎片,以支持云计算层次的扩展性
  • 支持RUBY(sass是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有三个特点:轻量性、可遍历性、高效性。

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

  • 非关系型数据库的优势:
  1. 性能

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

  1. 扩展性

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

  • 关系型数据库的优势:
  1. 复杂查询

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

  1. 事务支持

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

  • 总结
    数据库功能是用来存储数据的。
     数据库分为关系系数据库和非关系型数据库(nosql)
     关系型数据库是由表和表之间的关系组成的,nosql是由集合组成的,集合下面是很多的文档。
     非关系型数据库文件存储格式为BSON(一种JSON的扩展)。

MongoDB安装与使用

MongoDB官网地址:
https://www.mongodb.com/

MongoDB下载地址:
https://www.mongodb.com/download-center#community

MongoDB for Windows 64-bit 适合 64 位的 Windows Server 2008 R2, Windows 7 , 及最新版本的 Window 系统。

MongoDB for Windows 32-bit 适合 32 位的 Window 系统及最新的 Windows Vista。 32 位系统上 MongoDB 的数据库最大为 2GB。

选择适合自己系统的版本进行下载:

mongodb数据库 套壳 mongodb数据库表_数据_02


根据你的系统下载 32 位或 64 位的 .msi 文件,下载后双击该文件,按操作提示安装即可。

Robo 3T可视化工具安装


MongoDB的安装

对mongodb数据库的操作是通过执行命令来完成的,我的电脑里面这些命令安装在:

C:\Program Files\MongoDB\Server\3.2\bin

mongodb数据库 套壳 mongodb数据库表_mongodb_03


  要执行这些命令,需要以管理员身份运行cmd( 不建议用git来操作,因为git不是utf-8编码,会有中文乱码问题)。

  打开开始菜单,找到命令提示符,在上面点击右键,选择以管理员身份运行。

  要想执行mongodb的命令,需要cd到他的安装目录下面的bin文件夹下。

  为了在dos窗口的任何目录下都能执行mongo的命令,需要先设置环境变量,因为计算机在执行命令的时候会在环境变量中找对应的命令。

  不同的操作系统设置环境变量的步骤大同小异。

创建文件夹

  我们之前安装的其实是数据服务器,通过数据库服务器可以建立很多个数据库,我们打算把新建的数据库放哪里呢?需要指定一个位置。

  1、在d盘建立一个文件夹mongodb,并且建立子目录db和log。

  2、在log目录下建立一个文件MongoDB.log ,后缀为.log。

d:\mongodb\db、d:\mongodb\log, 分别用来存放数据库文件和数据库日志文件。

  3、把mongodb文件夹的只读属性去掉。

mongodb数据库 套壳 mongodb数据库表_数据库_04

启动MongoDB

mongodb数据库 套壳 mongodb数据库表_MongoDB_05


  以管理员身份运行cmd.exe,进入dos命令界面,执行下列命令

mongod --storageEngine mmapv1 --dbpath “d:\mongodb\db” --logpath “d:\mongodb\log\MongoDB.log”

mongodb数据库 套壳 mongodb数据库表_数据库_06


mongodb数据库 套壳 mongodb数据库表_MongoDB_07


  执行后,就挂起了,需要另外开命令窗口测试是否启动成功。

测试连接

  原来的cmd窗口不关闭,以管理员身份再开一个cmd窗口,输入mongo或者mongo.exe,出现如下信息说明测试通过,此时我们已经进入了test这个数据库。

mongodb数据库 套壳 mongodb数据库表_mongodb数据库 套壳_08


  从上图可以看出,我们进入了mongodb的shell

  输入exit或者ctrl+C可退出。

将MongoDB安装为windows服务

  当mongod.exe被关闭时,mongo.exe 就无法连接到数据库了,因此每次想使用mongodb数据库都要开启mongod.exe程序,所以比较麻烦,此时我们可以将MongoDB安装为windows服务。

以管理员身份运行cmd,进入bin文件夹,执行下列命令

mongod --storageEngine mmapv1 --dbpath “d:\mongodb\db” --logpath “d:\mongodb\log\MongoDB.log” --install --serviceName “MongoDB”

  这里MongoDB.log就是开始建立的日志文件,–serviceName “MongoDB” 服务名为MongoDB。

接着启动mongodb服务

NET START MongoDB
上面的命令不区分大小写

mongodb数据库 套壳 mongodb数据库表_数据_09


  打开任务管理器,可以看到进程已经启动。

  再次测试连接

mongo

关闭服务和删除进程

先: ctrl+c
然后关闭服务:net stop MongoDB


MongoDB基础使用

常用的命令

Help 查看帮助

mongodb数据库 套壳 mongodb数据库表_数据_10

  显示数据库列表 > 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() 则更改原来的内容为新内容。

  _id是主键,主键是每条数据的唯一标识,不能重复,就像身份证是每个人唯一的编号一样。

  存在数据:{ _id : ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老李"} ,_id是主键

  insert({ _id : ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老王 " }) 会提示错误

mongodb数据库 套壳 mongodb数据库表_数据库_11


  save(ObjectId(“57e8d34b4764fb71d0a89caa”), " name " : " 老王 " }) 会把 “老李” 改为 “ 老王” ,有update的作用。

mongodb数据库 套壳 mongodb数据库表_mongodb数据库 套壳_12

删除数据

  • 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,第一个参数是查找条件,第二个参数是修改内容,主键不能修改,第三个参数表示匹配所有符合条件的数据,第四个参数表示修改所有匹配到的数据如图

mongodb数据库 套壳 mongodb数据库表_mongodb数据库 套壳_13