mongodb是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居多。由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 MongoDB 因配置漏洞被攻击,数据被删,引起了人们的注意,感兴趣的可以看看这篇文章:场屠戮MongoDB的盛宴反思:超33000个数据库遭遇入侵勒索,同时也说明了很多公司生产中大量使用mongodb。
mongodb简介
MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是可以应用于各种规模的企业、各个行业以及各类应用程序的开源数据库。基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种。
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
传统的关系数据库一般由数据库(database)、表(table)、记录(record)三个层次概念组成,MongoDB是由数据库(database)、集合(collection)、文档对象(document)三个层次组成。MongoDB对于关系型数据库里的表,但是集合中没有列、行和关系概念,这体现了模式*的特点。
MongoDB中的一条记录就是一个文档,是一个数据结构,由字段和值对组成。MongoDB文档与JSON对象类似。字段的值有可能包括其它文档、数组以及文档数组。MongoDB支持OS X、Linux及Windows等操作系统,并提供了Python,PHP,Ruby,Java及C++语言的驱动程序,社区中也提供了对Erlang及.NET等平台的驱动程序。
MySQL的适合对大量或者无固定格式的数据进行存储,比如:日志、缓存等。对事物支持较弱,不适用复杂的多文档(多表)的级联查询。文中演示mongodb版本为3.4。
最近接手一个Springboot项目,需要在原项目上增加一些需求,用到了mongodb。一起看下集成之路吧!
1、首先pom.xml中引入mongodbDe依赖jar包
1
2
3
4
|
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
|
2、创建实体类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
@Document(collection = "spiderConfig" )
public class SpiderConfig implements Serializable {
@Id
private String id;
private String spiderConfig;
private long updateTime;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getSpiderConfig() {
return spiderConfig;
}
public void setSpiderConfig(String spiderConfig) {
this.spiderConfig = spiderConfig;
}
public long getUpdateTime() {
return updateTime;
}
public void setUpdateTime(long updateTime) {
this.updateTime = updateTime;
}
}
|
3、dao层操作mongodb的代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
@Component
public class SpiderConfigDaoImpl implements ISpiderConfigDao{
@Autowired
private MongoTemplate mongoTemplate;
@Override
public SpiderConfig findById(String id) {
Query query=new Query(Criteria. where ( "_id" ). is (id));
SpiderConfig user = mongoTemplate.findOne(query , SpiderConfig.class);
return user ;
}
@Override
public void saveSpiderConfig(SpiderConfig spiderConfig) {
mongoTemplate.save(spiderConfig);
}
}
|
4、在application.properties中设置monggodb数据库的相关配置信息
1
2
|
#mongodb配置
spring.data.mongodb.uri=mongodb://192.168.86.888:27017/test
|
到此相关信息配置已完成,测试验证与数据库的交互都正确!
总结
以上所述是小编给大家介绍的Sprint Boot 集成MongoDB的操作方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://www.linuxidc.com/Linux/2017-11/148919.htm