数据库
-
概念:数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据库技术得到了更加快速的发展,应用得更加广泛。主要用它进行管理各种系统的数据,作为科学研究和决策的重要技术手段。
-
常见数据库有哪些?
- orade mysql等等
- 关系型数据库(sql):Access mySql SqlServer oracle db2等。
- 非关系型数据库( NoSql ): MongoDB,Redis,HBase,CouchDB等。
- 什么是关系型数据库?
关系型数据库 以行和列的形式存储数据,以便于用户理解。这一系列的行和列被称为表,一组表组成了数据库。表与表之间的数据记录有关系。
MongoDB简介
概念:
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
MongoDB优点
- 它的特点是高性能、易部署、易使用,存储数据非常方便,特性有:
1.面向集合存储,易存储对象类型的数据。
2.模式自由。
3.支持动态查询。
4.支持完全索引,包含内部对象。
5.支持查询。
6.支持复制和故障恢复。
7.使用高效的二进制数据存储,包括大型对象(如视频等)。
9.自动处理碎片,以支持云计算层次的扩展 性
10.支持RUBY,PYTHON,JAVA,C++,PHP等多种语言。
11.文件存储格式为BSON(一种JSON的扩展)
BSON
- BSON是一种类似json的二进制形式的存储格式,简称Binary JSON,它和JSON一样,支持内嵌的文档对象和数组对象,但是BSON有JSON没有的一些数据类型,如Date和BinData类型。
- BSON可以做为网络数据交换的一种存储形式,这个有点类似于Google的Protocol Buffer,但是BSON是一种schema-less的存储形式,它的优点是灵活性高,但它的缺点是空间利用率不是很理想。
- BSON有三个特点:轻量性、可遍历性、高效性
非关系型数据库与关系型数据库区别
- 非关系型数据库的优势:
- 性能,
NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL层的解析,所以性能非常高。 - 可扩展性,
同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展。
- 关系型数据库的优势:
- 复杂查询,可以用SQL语句方便的在多个表之间做非常复杂的数据查询。
- 事务支持,使得对于安全性能很高的数据访问要求得以实现。
MongoDB下载与安装
MongoDB官网地址:
https://www.mongodb.com/
MongoDB下载地址:https://www.mongodb.com/download-center#community
MongoDB基础使用
- help 查看帮助
- show dbs 显示数据库列表
- use dbname 如果数据库不存在,则创建数据库dbname,否则切换到指定数据库dbname。
- show collections 显示数据库中的集合
增加数据
- db.web.save({“name”:“老李”}) 创建了名为web的集合,并新增了一条{“name”:“老李”} 的数据
- b.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,第一个参数是查找条件,第二个参数是修改内容,主键不能修改,第三个参数表示匹配所有符合条件的数据,第四个参数表示修改所有匹配到的数据
mongoose
Mongoose简介
- Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用。
- 官方文档:https://www.npmjs.com/package/mongoose
http://mongoosejs.com/
Mongoose的操作流程
安装mongoose
- npm install mongoose
连接数据库
使用mongoose连接数据库的前提条件是:
- mongo数据库已经运行。
- 已经安装了mongoose包