MongoDB
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
1.关系型数据库遵循ACID规则
事务在英文中是transaction,和现实世界中的交易很类似,它有如下四个特性:
1、A (Atomicity) 原子性
原子性很容易理解,也就是说事务里的所有操作要么全部做完,要么都不做,事务成功的条件是事务里的所有操作都成功,只要有一个操作失败,整个事务就失败,需要回滚。
比如银行转账,从A账户转100元至B账户,分为两个步骤:1)从A账户取100元;2)存入100元至B账户。这两步要么一起完成,要么一起不完成,如果只完成第一步,第二步失败,钱会莫名其妙少了100元。
2、C (Consistency) 一致性
一致性也比较容易理解,也就是说数据库要一直处于一致的状态,事务的运行不会改变数据库原本的一致性约束。
例如现有完整性约束a+b=10,如果一个事务改变了a,那么必须得改变b,使得事务结束后依然满足a+b=10,否则事务失败。
3、I (Isolation) 独立性
所谓的独立性是指并发的事务之间不会互相影响,如果一个事务要访问的数据正在被另外一个事务修改,只要另外一个事务未提交,它所访问的数据就不受未提交事务的影响。
比如现有有个交易是从A账户转100元至B账户,在这个交易还未完成的情况下,如果此时B查询自己的账户,是看不到新增加的100元的。
4、D (Durability) 持久性
持久性是指一旦事务提交后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。
2.NoSQL 简介
NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL"。
2.1什么是NoSQL?
NoSQL,指的是非关系型的数据库。NoSQL有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统的统称。
NoSQL用于超大规模数据的存储。(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据)。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。
2.2为什么使用NoSQL ?
今天我们可以通过第三方平台(如:Google,Facebook等)可以很容易的访问和抓取数据。用户的个人信息,社交网络,地理位置,用户生成的数据和用户操作日志已经成倍的增加。我们如果要对这些用户数据进行挖掘,那SQL数据库已经不适合这些应用了, NoSQL数据库的发展也却能很好的处理这些大的数据。
2.3NoSQL的优点/缺点
优点:
- 高可扩展性
- 分布式计算
- 低成本
- 架构的灵活性,半结构化数据
- 没有复杂的关系
缺点:
- 没有标准化
- 有限的查询功能(到目前为止)
- 最终一致是不直观的程序
3.什么是MongoDB
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
4.MongoDB 概念解析
不管我们学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是文档、集合、数据库,下面我们挨个介绍。
下表将帮助您更容易理解Mongo中的一些概念:
SQL术语/概念|MongoDB术语/概念|解释/说明
:--:|:--:
database|database|数据库
table|collection|数据库表/集合
row|document|数据记录行/文档
column|field|数据字段/域
index|index|索引
table joins||表连接,MongoDB不支持
primary key|primary key|主键,MongoDB自动将_id字段设置为主键
通过下图实例,我们也可以更直观的的了解Mongo中的一些概念:
5.常用命令
mongod -version
mongod --dbpath c:/data
mongo
show dbs
use ssm
db
db.dropDatabase()
db.student.insert({name:"kygo", age:22, tel:18908421424})
db.student.find()
Spring整合MongoDB
1.添加jar包(maven管理)
spring-data-mongodb
2.配置applicationContext.xml
<mongo:repositories base-package="com.kygo.ssm.dao" />
这个命名空间元素将导致基础软件包,以延长接口进行扫描MongoRepository,并为他们每个人找到创建的Spring beans。
默认情况下,存储库将获得MongoTemplate的Spring bean有线那个叫mongoTemplate,所以你只需要配置mongo-template-ref,如果你从这个约定偏离明确。
<mongo:mongo host="127.0.0.1" port="27017" />
Mongo是入口点的MongoDB驱动程序API,连接到特定的MongoDB数据库实例需要额外的信息,如数据库名和一个可选的用户名和密码。使用该信息,您可以获取一个com.mongodb.DB对象并访问特定MongoDB数据库实例的所有功能。
<mongo:db-factory dbname="ssm" mongo-ref="mongo" />
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg name="mongoDbFactory" ref="mongoDbFactory"/>
</bean>
该类MongoTemplate位于包org.springframework.data.mongodb.core,是中央级的Spring的MongoDB的支持,提供了丰富的功能设置为与数据库进行交互。该模板提供了方便的操作来创建,更新,删除和查询MongoDB文档,并提供域对象和MongoDB文档之间的映射。
3.例子:学生实体
@Document
public class Student {
private String name;
private int age;
private String tel;
}
4.dao层
public interface StudentDao extends MongoRepository<Student, String> {
}
继承 MongoRepository接口,有许多默认的crud方法。