万云 發表於 2019-11-7 12:55:00

SpringBoot整合MongoDB

<p>本节使用SpringBoot 2.1.9.RELEASE,<strong>示例源码</strong>在https://github.com/laolunsi/spring-boot-examples</p>
<hr>
<p>SpringBoot可以非常方便地引入和操作MongoDB。本节分两部分,记录个人学习SpringBoot使用MongoDB数据库的一些知识。</p>
<p>第一部分是一个简单的springboot连接mongo的demo,测试查询功能。</p>
<p>第二部分是基于mongo实现的增删改查数据示例。</p>
<hr>
<h2 id="一a-simple-demo">一、A simple demo</h2>
<p>首先来演示SpringBoot项目引入MongoDB,以及一个简单的findAll操作。</p>
<p>maven依赖:</p>
<pre><code class="language-xml">&lt;dependency&gt;
   &lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;
   &lt;artifactId&gt;spring-boot-starter-data-mongodb&lt;/artifactId&gt;
&lt;/dependency&gt;
</code></pre>
<p>环境配置:</p>
<p>application.yml文件中写入如下配置,test表示MongoDB中的test库</p>
<pre><code class="language-yml">spring:
data:
    mongodb:
      uri: "mongodb://localhost:27017/test"
</code></pre>
<p>以一个bean类为例:</p>
<pre><code class="language-java">package com.example;

public class User {

    private String id;
    private String name;
    private Integer age;
    private Integer grade;

    // ... ignore getter and setter
   
   
    // override its toString method
    @Override
    public String toString() {
      return "User{" +
                "id='" + id + '\'' +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", grade=" + grade +
                '}';
    }
}

</code></pre>
<p>在MongoDB数据库中新建一个collection(也就是表),名字叫user,插入几条数据,比如:</p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125517717-1717302505.png"><br>
注:这里用的可视化工具是robo 3t:https://robomongo.org/</p>
<p>我们这里先默认JavaBean的字段与user表的字段名保持一致。</p>
<p>下面我们编写测试类:</p>
<pre><code class="language-java">@SpringBootTest
@RunWith(SpringRunner.class)
public class MongoTest {

    @Autowired
    private MongoTemplate mongoTemplate;

    @Test
    public void test1() {
      List&lt;User&gt; userList = mongoTemplate.findAll(User.class);
      if (userList != null &amp;&amp; userList.size() &gt; 0) {
            userList.forEach(user -&gt; {
                System.out.println(user.toString());
            });
      }
    }

}

</code></pre>
<p>运行测试类,输出如下:</p>
<pre><code class="language-powershell">User{id='5d243534514701183f5fcab8', name='zf0', age=12, grade=1}
User{id='5d243534514701183f5fcab9', name='zf1', age=13, grade=2}
User{id='5d243534514701183f5fcaba', name='zf2', age=14, grade=3}
User{id='5d243534514701183f5fcabb', name='zf3', age=15, grade=4}
User{id='5d243534514701183f5fcabc', name='zf4', age=16, grade=5}
</code></pre>
<hr>
<h2 id="二基于springboot的mongodb增删改查操作">二、基于SpringBoot的MongoDB增删改查操作</h2>
<p>下面来实现一个基于SpringBoot的对MongoDB增删改查操作的简单示例,依然使用上面的环境:</p>
<p>maven:</p>
<pre><code class="language-xml">&lt;dependency&gt;
        &lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;
    &lt;artifactId&gt;spring-boot-starter-web&lt;/artifactId&gt;
&lt;/dependency&gt;

&lt;dependency&gt;
    &lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;
    &lt;artifactId&gt;spring-boot-starter-test&lt;/artifactId&gt;
    &lt;scope&gt;test&lt;/scope&gt;
&lt;/dependency&gt;

&lt;dependency&gt;
    &lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;
    &lt;artifactId&gt;spring-boot-starter-data-mongodb&lt;/artifactId&gt;
&lt;/dependency&gt;

&lt;dependency&gt;
        &lt;groupId&gt;com.alibaba&lt;/groupId&gt;
    &lt;artifactId&gt;fastjson&lt;/artifactId&gt;
    &lt;version&gt;1.2.60&lt;/version&gt;
&lt;/dependency&gt;
</code></pre>
<p>yml:</p>
<pre><code class="language-yaml">server:
port: 8866

spring:
data:
    mongodb:
      uri: "mongodb://localhost:27017/test"
</code></pre>
<p>User类:</p>
<p>这里我们清楚一下之前的数据,把mongo里的user表里的数据全部删掉。</p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125517925-85956189.png"></p>
<p>注:这里用的可视化工具admin-mongo:https://github.com/mrvautin/adminMongo</p>
<p>新建一个不同的user类:</p>
<pre><code class="language-java">@Document("user")
public class User {

    @Id
    private String id;

    @Field("name")
    private String name;

    @Field("password")
    private String password;

    @Field("address")
    private String address;

    @Field("create_time")
    private Date createTime;

    @Field("last_update_time")
    private Date lastUpdateTime;

    // ... ignore getter and setter methods

    @Override
    public String toString() {
      return JSONObject.toJSONString(this);
    }
}

</code></pre>
<p>此处定义一个JsonResult类,用于封装接口返回数据:</p>
<pre><code class="language-java">import com.alibaba.fastjson.JSONObject;

import java.util.HashMap;
import java.util.Map;

public class JsonResult {

    /**
   * 未登录
   */
    public static final int NO_LOGIN = 400;

    /**
   * 登录失败
   */
    public static final int LOGIN_FAILED = 401;

    /**
   * TOKEN过期
   */
    public static final int TOKEN_EXPIRED = 402;

    /**
   * 无权限
   */
    public static final int NO_PERMISSION = 403;


    private Boolean success;
    private Integer code;
    private String msg;
    private Object data;

    public JsonResult(Boolean success) {
      this.success = success;
    }

    public JsonResult(Boolean success, String msg) {
      this.success = success;
      this.msg = msg;
    }

    public JsonResult(Integer code, Boolean success, String msg) {
      this.code = code;
      this.success = success;
      this.msg = msg;
    }

    public JsonResult(Boolean success, Object data) {
      this.success = success;
      this.data = data;
    }

    public JsonResult(Boolean success, Integer code, String msg, Object data) {
      this.success = success;
      this.code = code;
      this.msg = msg;
      this.data = data;
    }

    // ... ignore getter and setter methods

    public void put(String key, Object value) {
      if (data == null) {
            data = new HashMap&lt;&gt;();
      }
      ((Map) data).put(key, value);
    }

    public void putAll(Map&lt;String, Object&gt; map) {
      if (data == null) {
            data = new HashMap&lt;&gt;();
      }
      ((Map) data).putAll(map);
    }

    @Override
    public String toString() {
      return JSONObject.toJSONString(this);
    }
}


</code></pre>
<p>下面编写测试接口类,实现用户的新增、删除、更新、查询功能</p>
<p>UserController类:</p>
<pre><code class="language-java">@RestController
@RequestMapping(value = "user")
public class UserController {

    @Autowired
    private MongoTemplate mongoTemplate;

    @GetMapping(value = "")
    public JsonResult list() {
      List&lt;User&gt; userList = mongoTemplate.findAll(User.class, "user");
      return new JsonResult(true, userList);
    }

    @PostMapping(value = "")
    public JsonResult add(User user) {
      String msg = verifySaveForm(user);
      if (!StringUtils.isEmpty(msg)) {
            return new JsonResult(false, msg);
      }

      if (user.getId() == null) {
            user.setCreateTime(new Date());
            user.setLastUpdateTime(new Date());
            User newUser = mongoTemplate.insert(user, "user");
            return new JsonResult(true, newUser);
      } else {
            Query query = new Query();
            query.addCriteria(Criteria.where("_id").is(user.getId()));

            Update update = new Update();
            update.set("name", user.getName());
            update.set("password", user.getPassword());
            update.set("address", user.getAddress());
            update.set("last_update_time", new Date());

            UpdateResult updateResult = mongoTemplate.updateFirst(query, update, "user");
            return new JsonResult(true, updateResult);
      }
    }

    @DeleteMapping(value = "{id}")
    public JsonResult delete(@PathVariable String id) {
      Query query = new Query();
      query.addCriteria(Criteria.where("_id").is(id));
      DeleteResult deleteResult = mongoTemplate.remove(query, User.class, "user");
      return new JsonResult(true, deleteResult);
    }

    // private methods

    private String verifySaveForm(User user) {
      if (user == null || StringUtils.isEmpty(user.getName())) {
            return "用户名不能为空";
      } else if (user.getPassword() == null) {
            return "密码不能为空";
      }

      return null;
    }
}

</code></pre>
<p>下面用postman模拟一下请求:</p>
<p><strong>新增用户</strong>:</p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125518279-753302960.png"></p>
<p><strong>查看Mongodb</strong>:</p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125518438-1472548223.png"></p>
<p><strong>更改数据,新增多个用户</strong>:</p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125518852-1451748587.png"></p>
<p><strong>列表查询</strong>:</p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125519564-1660719776.png"></p>
<p><strong>更改user</strong>:</p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125519812-943560993.png"></p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125520259-319268585.png"></p>
<p><strong>删除user</strong>:<br>
<img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125520457-2131467337.png"></p>
<p><img src="https://img2018.cnblogs.com/blog/1860493/201911/1860493-20191107125520928-245087924.png"></p>
<hr>
<p>好,到此为止,我们已经在SpringBoot项目中引入了MongoDB,并实现了基本的增删改查操作,这将是我们使用MongoDB开发更加复杂的业务的基础!</p><br><br>
来源:https://www.cnblogs.com/eknown/p/11811394.html
頁: [1]
查看完整版本: SpringBoot整合MongoDB