84. Spring Boot集成MongoDB【从零开始学Spring Boot】

至于MongoDB网上有很多相关的资料,所以在这里不进行过多的介绍,我们在这里主要是介绍下如何将mongodb与spring boot结合使用。本节大纲:

(1) 准备工作;

(2) 新建一个maven java project;

(3) 引入相关依赖;

(4) 编写测试代码;

(5) 配置文件;

(6) 使用MongoTemplate进行操作;

接下来一起看看每个步骤都是怎么操作的吧。

(1) 准备工作;

既然需要使用mongodb,那么很明显就需要安装mongodb 服务。这个网络上有很多相关的资料,自行进行操作。

下载安装完,把mongodb服务启动起来以备之后进行操作使用。

(2) 新建一个maven java project;

在这里我们新建一个spring-boot-mongodb项目。

(3) 引入相关依赖;

引入相关依赖,在这里最主要的是mongodb的依赖,其它的依赖就是基本的了,具体看如下pom.xml文件:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

<modelVersion>4.0.0</modelVersion>

<groupId>com.kfit</groupId>

<artifactId>spring-boot-mongodb</artifactId>

<version>0.0.1-SNAPSHOT</version>

<packaging>jar</packaging>

<name>spring-boot-mongodb</name>

<url>http://maven.apache.org</url>

<properties>

<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

<!-- jdk版本号,angel在这里使用1.8,大家修改为大家本地配置的jdk版本号即可 -->

<java.version>1.8</java.version>

</properties>

<!--

spring boot 父节点依赖,

引入这个之后相关的引入就不需要添加version配置,

spring boot会自动选择最合适的版本进行添加。

-->

<parent>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-parent</artifactId>

<version>1.3.3.RELEASE</version>

</parent>

<dependencies>

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

</dependency>

<!-- spring boot web支持:mvc,aop... -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-web</artifactId>

</dependency>

<!-- 增加mongodb支持 -->

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-data-mongodb</artifactId>

</dependency>

</dependencies>

</project>

(4) 编写测试代码;

在这里我们需要编写一个简单的例子进行测试下,我们需要创建一个DemoInfo实体类,需要创建一个操作MongoDB的repository类,再者就是一个控制类DemoController。具体看如下代码:

实体类代码DemoInfo:com.kfit.demo.DemoInfo ,具体代码如下:

package com.kfit.demo;

import org.springframework.data.annotation.Id;

/**

* 实体类.

* @author Angel --守护天使

* @version v.0.1

* @date 2016年8月18日下午3:15:39

*/

public class DemoInfo {

//id属性是给mongodb用的,用@Id注解修饰

@Id

private String id;

private String name;

privateintage;

public String getName() {

returnname;

}

public void setName(String name) {

this.name = name;

}

public int getAge() {

return age;

}

public void setAge(intage) {

this.age = age;

}

@Override

public String toString() {

return "DemoInfo [id=" + id + ", name=" + name + ", age=" + age + "]";

}

}

这个类很简单,跟普通的实体类相比就是多了一个id的注解,这给Mongodb使用的。

接下来编写一个操作mongodb的repository代码,它继承MongoRepository接口;MongoRepository接口包含了常用的CRUD操作,例如:save,insert,fillAll等。我们也可以定义我们自己的操作接口,具体看如下代码:

com.kfit.demo.DemoInfoRepository :

 

package com.kfit.demo;

import org.springframework.data.mongodb.repository.MongoRepository;

/**

* 继承自MongoRepository接口,MongoRepository接口包含了常用的CRUD操作,

* 例如:save、insert、findall等等。我们可以定义自己的查找接口,

* 例如根据demoInfo的name搜索,具体的DemoInfoRepository接口代码如下:

* @author Angel --守护天使

* @version v.0.1

* @date 2016年8月18日下午3:15:49

*/

public interface  DemoInfoRepository  extends MongoRepository<DemoInfo, String> {

DemoInfo findByName(String name);

}

接下来就是访问控制类,这个类中很简单,都是最基本的代码,看如下:

com.kfit.demo.DemoController:

package com.kfit.demo;

import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;

/**

*

* @author Angel --守护天使

* @version v.0.1

* @date 2016年8月18日下午8:49:35

*/

@RestController

public class DemoController {

@Autowired

private DemoInfoRepository demoInfoRepository;

@RequestMapping("save")

public String save(){

DemoInfo demoInfo = new DemoInfo();

demoInfo.setName("张三");

demoInfo.setAge(20);

demoInfoRepository.save(demoInfo);

demoInfo = new DemoInfo();

demoInfo.setName("李四");

demoInfo.setAge(30);

demoInfoRepository.save(demoInfo);

return "ok";

}

@RequestMapping("find")

public List<DemoInfo> find(){

return demoInfoRepository.findAll();

}

@RequestMapping("findByName")

public DemoInfo findByName(){

return demoInfoRepository.findByName("张三");

}

}

最后编写App.java启动类,启动应用程序:

com.kfit.App:

package com.kfit;

import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;

/**

*

* @author Angel --守护天使

* @version v.0.1

* @date 2016年8月18日下午3:15:28

*/

@SpringBootApplication

public class App {

public static void main(String[] args) {

SpringApplication.run(App.class, args);

}

}

好了到这里,简单的一个程序就可以运行起来看看了,运行起来之后,依次访问如下地址:

http://127.0.0.0.1:8080/save :保存两条数据;

http://127.0.0.0.1:8080/find  :查询所有数据;

http://127.0.0.0.1:8080/findByName  :通过名称查找;

只要在浏览器中能看到数据,那么恭喜你,基本的使用算是成功了。那么你肯定会有疑问,看下文。

(5) 配置文件

我们会发现我们根本没有做什么配置,所以spring boot提供了默认的一些配置,比如地址,端口号,那么如果我们修改了mongodb默认的端口号27017,Spring boot 也给我们配置的地方application.properties文件,具体支持如下一些配置:

# MONGODB (MongoProperties)

spring.data.mongodb.authentication-database= # Authentication database name.

spring.data.mongodb.database=test # Database name.

spring.data.mongodb.field-naming-strategy= # Fully qualified name of the FieldNamingStrategy to use.

spring.data.mongodb.grid-fs-database= # GridFS database name.

spring.data.mongodb.host=localhost # Mongo server host.

spring.data.mongodb.password= # Login password of the mongo server.

spring.data.mongodb.port=27017 # Mongo server port.

spring.data.mongodb.repositories.enabled=true # Enable Mongo repositories.

spring.data.mongodb.uri=mongodb://localhost/test # Mongo database URI. When set, host and port are ignored.

spring.data.mongodb.username= # Login user of the mongo server.

(6) 使用MongoTemplate进行操作;

首先在DemoController中引入MongoTemplate :

@Autowired

private MongoTemplate mongoTemplate;

编写访问方法:

@RequestMapping("find2")

public List<DemoInfo> find2(){

return mongoTemplate.findAll(DemoInfo.class);

}

访问地址:http://127.0.0.1:8080/find2 ,如果看到和find一样的数据,恭喜你你成功了。好了暂时就介绍到这里。

上一篇:Spring Boot开发MongoDB应用实践


下一篇:目标跟踪_MeanShift