一、MongoDB概述
简介
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
基础概念
在mongodb中基本的概念是文档、集合、数据库,下面我们挨个介绍。
下表将帮助您更容易理解Mongo中的一些概念:
SQL术语/概念 | MongoDB术语/概念 | 解释/说明 |
database | database | 数据库 |
table | collection | 数据库表/集合 |
row | document | 数据记录行/文档 |
column | field | 数据字段/域 |
index | index | 索引 |
table joins |
| 表连接,MongoDB不支持 |
primary key | primary key | 主键,MongoDB自动将_id字段设置为主键 |
主要特性
MongoDB 包含以下特点:
a 面向集合的存储:适合存储对象及JSON形式的数据。
b 动态查询:Mongo 支持丰富的查询方式,查询指令使用 JSON 形式的标记,可轻易查询文档中内嵌的对象及数组。
c 完整的索引支持:包括文档内嵌对象及数组。Mongo 的查询优化器会分析查询表达式,并生成一个高效的查询计划。
d 查询监视:Mongo包含一个监控工具用于分析数据库操作性能。
e 复制及自动故障转移:Mongo 数据库支持服务器之间的数据复制,支持主-从模式及服务器之间的相互复制。复制的主要目的是提供冗余及自动故障转移。
f 高效的传统存储方式:支持二进制数据及大型对象(如:照片或图片)。
g 自动分片以支持云级别的伸缩性:自动分片功能支持水平的数据库集群,可动态添加额外的机器。
二、MongoDB与 springMVC整合
环境
jdk1.8,spring-4.3.12.RELEASE
Maven依赖
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-mongodb</artifactId>
<version>1.9.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongo-java-driver</artifactId>
<version>2.14.3</version>
</dependency>
配置
1,mongodb.propertise的配置(示例供参考)
mongo.hostport=127.0.0.1:27017
mongo.connectionsPerHost=8
mongo.threadsAllowedToBlockForConnectionMultiplier=4
#\u8FDE\u63A5\u8D85\u65F6\u65F6\u95F4
mongo.connectTimeout=1000
#\u7B49\u5F85\u65F6\u95F4
mongo.maxWaitTime=1500
mongo.autoConnectRetry=true
mongo.socketKeepAlive=true
#Socket\u8D85\u65F6\u65F6\u95F4
mongo.socketTimeout=1500
mongo.slaveOk=true
2,web.xml配置
3,Spring公共配置applicationContext-main.xml加载mongodb.properties
4,配置applicationContext-mongo.xml
三、基本操作
//新增
public void save(Object objectToSave)
//删除
public WriteResult remove(Object object)
//修改一个
public WriteResult updateFirst(Query query, Update update, Class<?> entityClass)
//修改多条记录
public WriteResult updateMulti(Query query, Update update, Class<?> entityClass)
//查第一个对象
public <T> T findOne(Query query, Class<T> entityClass)
//查对象列表
public <T> List<T> find(Query query, Class<T> entityClass)
等等
四、相关注解
@Document - 用于类,以表示这个类需要映射到数据库,您也可以指定映射到数据库的集合名称
@Id - 用于字段级别,标记这个字段是一个主键,默认生成的名称是“_id”
@DBRef - 用于字段,以表示它将使用com.mongodb.DBRef进行存储。
@Indexed - 用于字段,表示该字段需要如何创建索引
@CompoundIndex - 用于类,以声明复合索引
@GeoSpatialIndexed - 用于字段,进行地理位置索引
@TextIndexed - 用于字段,标记该字段要包含在文本索引中
@Field - 用于字段,并描述字段的名称,因为它将在MongoDB BSON文档中表示,允许名称与该类的字段名不同。
@Version - 用于字段锁定,保存操作时检查修改。初始值是0,每次更新时自动触发。
@Language - 用于字段,以设置文本索引的语言覆盖属性。
@Transient - 默认情况下,所有私有字段都映射到文档,此注解将会去除此字段的映射
@PersistenceConstructor - 标记一个给定的构造函数,即使是一个protected修饰的,在从数据库实例化对象时使用。构造函数参数通过名称映射到检索的DBObject中的键值。
五、实例代码示范
@Autowired
MongoTemplate mongoTemplate;
//增
@Test
public void saveObj(){
KeyValue t = new KeyValue();
t.setKey("book");
t.setValue("javaScript");
mongoTemplate.save(t);
System.out.println("新增成功");
}
//删
@Test
public void removeObj(){
//查询第一条数据并删除
KeyValue t = mongoTemplate.findOne(Query.query(Criteria.where("")),KeyValue.class);
mongoTemplate.remove(t);
}
//改
@Test
public void updateObj(){
Query query = new Query();
Update update = Update.update("value","python");
mongoTemplate.updateFirst(query, update, KeyValue.class);
mongoTemplate.updateMulti(query, update, KeyValue.class);
}
//查
@Test
public void getMongoValue(){
String key = "book";
KeyValue ret = mongoTemplate.findOne(new Query(Criteria.where("key").is(key)), KeyValue.class);
System.out.println(JSON.toJSONString(ret));
}
@Test
public void getMongoValueListTest(){
String key = "book";
List<KeyValue> ret = mongoTemplate.find(new Query(Criteria.where("key").is(key)), KeyValue.class);
System.out.println(JSON.toJSONString(ret));
}
@Test
public void getMongoCollectionNameTest(){
String ret = mongoTemplate.getCollectionName(KeyValue.class);
System.out.println(ret);
}
}
下面是测试运行结果
1,测试新增
2,测试查询一条
3,测试查询列表
更多操作请参考官方文档