当前位置: 首页 > 编程笔记 >

SpringBoot轻松整合MongoDB的全过程记录

湛铭
2023-03-14
本文向大家介绍SpringBoot轻松整合MongoDB的全过程记录,包括了SpringBoot轻松整合MongoDB的全过程记录的使用技巧和注意事项,需要的朋友参考一下

前言

MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

提示:以下是本篇文章正文内容,下面案例可供参考

一、技术介绍

1.MongoDB是什么?

MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是可以应用于各种规模的企业、各个行业以及各类应用程序的开源数据库。作为一个适用于敏捷开发的数据库,MongoDB的数据模式可以随着应用程序的发展而灵活地更新。与此同时,它也为开发人员 提供了传统数据库的功能:二级索引,完整的查询系统以及严格一致性等等。 MongoDB能够使企业更加具有敏捷性和可扩展性,各种规模的企业都可以通过使用MongoDB来创建新的应用,提高与客户之间的工作效率,加快产品上市时间,以及降低企业成本。

MongoDB是专为可扩展性,高性能和高可用性而设计的数据库。它可以从单服务器部署扩展到大型、复杂的多数据中心架构。利用内存计算的优势,MongoDB能够提供高性能的数据读写操作。 MongoDB的本地复制和自动故障转移功能使您的应用程序具有企业级的可靠性和操作灵活性。

二、使用步骤

1.引入maven库

代码如下(示例):

	 <parent>
	  <groupId>org.springframework.boot</groupId>
	  <artifactId>spring-boot-starter-parent</artifactId>
	  <version>2.4.1</version>
	  <relativePath/>
	 </parent>
  <dependencies>
  <dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-data-mongodb</artifactId>
  </dependency>
 </dependencies>

2.具体使用示例

MongoDB封装:

/**
 * mongo db助手
 *
 * @Author: heyuhua
 * @Date: 2021/1/19 9:52
 */
@Component
public class MongoDBHelper {

 @Autowired
 private MongoTemplate mongoTemplate;

 /**
  * 保存
  *
  * @param t
  * @param <T>
  * @return
  */
 public <T> T save(T t) {
  return mongoTemplate.save(t);
 }

 /**
  * 保存
  *
  * @param t
  * @param collectionName
  * @param <T>
  * @return
  */
 public <T> T save(T t, String collectionName) {
  return mongoTemplate.save(t, collectionName);
 }

 /**
  * 查询
  *
  * @param query
  * @param tClass
  * @param <T>
  * @return
  */
 public <T> List<T> find(Query query, Class<T> tClass) {
  return mongoTemplate.find(query, tClass);
 }

 /**
  * 查询所有
  *
  * @param tClass
  * @param <T>
  * @return
  */
 public <T> List<T> findAll(Class<T> tClass) {
  return mongoTemplate.findAll(tClass);
 }


}

3.配置文件

代码如下(示例):

server:
 port: 8088


spring:
 #mongodb配置
 data:
 mongodb:
  uri: mongodb://admin:admin@127.0.0.1:27017/admin


4.单元测试

测试代码如下(示例):

 package com.hyh.core.test;

import com.hyh.core.test.base.HyhTest;
import com.hyh.core.test.po.Person;
import com.hyh.mongodb.helper.MongoDBHelper;
import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.CriteriaDefinition;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.TextCriteria;

import java.util.List;

/**
 * MongoDb Test
 *
 * @Author: heyuhua
 * @Date: 2021/1/19 10:28
 */
public class MongoDBTest extends HyhTest {

 @Autowired
 private MongoDBHelper mongoDBHelper;


 @Test
 public void testSave() {
  Person person = new Person();
  person.setName("heyuhua");
  person.setAge(25);
  mongoDBHelper.save(person);
  Person person2 = new Person();
  person2.setName("hyh");
  person2.setAge(52);
  mongoDBHelper.save(person2);
 }

 @Test
 public void testSaveCollection() {
  Person person = new Person();
  person.setName("heyuhua");
  person.setAge(25);
  mongoDBHelper.save(person, "personCollection");
  Person person2 = new Person();
  person2.setName("hyh");
  person2.setAge(52);
  mongoDBHelper.save(person2, "personCollection");
 }

 @Test
 public void testFindAll() {
  List<Person> list = mongoDBHelper.findAll(Person.class);
  for (Person person : list) {
   System.out.println("name=" + person.getName() + ",age=" + person.getAge());
  }
 }

 @Test
 public void testFind() {
  Criteria criteria = new Criteria();
  criteria.and("age").gte("25");
  Query query = new Query(criteria);
  List<Person> list = mongoDBHelper.find(query,Person.class);
  for (Person person : list) {
   System.out.println("name=" + person.getName() + ",age=" + person.getAge());
  }
 }

 @Test
 @Override
 public void test() {
  System.out.println("---MongoDb Test---");
 }


}


总结

是不是感觉很简单?更多用法请点击下方查看源码,关注我带你揭秘更多高级用法

源码地址:点此查看源码.

到此这篇关于SpringBoot轻松整合MongoDB的文章就介绍到这了,更多相关SpringBoot轻松整合MongoDB内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!

 类似资料:
  • 本文向大家介绍详解springboot整合mongodb,包括了详解springboot整合mongodb的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍springboot如何整合MongoDB。 准备工作 安装 MongoDB jdk 1.8 maven 3.0 idea 环境依赖 在pom文件引入spring-boot-starter-data-mongodb依赖: 数据源配置 如

  • 本文向大家介绍SpringBoot整合ActiveMQ过程解析,包括了SpringBoot整合ActiveMQ过程解析的使用技巧和注意事项,需要的朋友参考一下 目录结构 引入 maven依赖 引入 application.yml配置 创建QueueConfig 创建生产者: 创建消费者的application.yml 创建消费者: 结果显示: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希

  • 本文向大家介绍Springboot整合junit过程解析,包括了Springboot整合junit过程解析的使用技巧和注意事项,需要的朋友参考一下 对maven项目的pom.xml进行配置 测试类如图所示 junit5可直接扫描测试的主启动类 也不需要加@runwith注解 只需要加@SpringBootTest 注解 也不需要指定主启动类的class文件 以上就是本文的全部内容,希望对大家的学习

  • 本文向大家介绍SpringBoot SSO轻松实现(附demo),包括了SpringBoot SSO轻松实现(附demo)的使用技巧和注意事项,需要的朋友参考一下 前言 网上SSO的框架很多,此篇文章使用的是自写的SSO来实现简单的登录授权功能,目的在于扩展性,权限这方面,自写扩展性会好点。 提示:以下是本篇文章正文内容,下面案例可供参考 一、技术介绍 1.SSO是什么? 单点登录(SingleS

  • 本文向大家介绍SpringBoot整合Lettuce redis过程解析,包括了SpringBoot整合Lettuce redis过程解析的使用技巧和注意事项,需要的朋友参考一下 首先解释一下Lettuce客户端: Lettuce 和 Jedis 的都是连接Redis Server的客户端程序。Jedis在实现上是直连redis server,多线程环境下非线程安全,除非使用连接池,为每个Jedi

  • 本文向大家介绍SpringBoot整合Xxl-Job的完整步骤记录,包括了SpringBoot整合Xxl-Job的完整步骤记录的使用技巧和注意事项,需要的朋友参考一下 一、下载Xxl-Job源代码并导入本地并运行 Github地址: https://github.com/xuxueli/xxl-job 中文文档地址: https://www.xuxueli.com/xxl-job/ 1.使用Ide