开始进入正题
一、技术介绍
SpringBoot整合MongoDB的实现步骤
- 一、技术介绍
- 1.MongoDB是什么?
- 二、使用步骤
1.MongoDB是什么?
MongoDB
(来自于英文单词“Humongous
”,中文含义为“庞大”)是可以应用于各种规模的企业、各个行业以及各类应用程序的开源数据库。作为一个适用于敏捷开发的数据库,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 {@Autowiredprivate 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: 8088spring:#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 {@Autowiredprivate MongoDBHelper mongoDBHelper;@Testpublic 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);}@Testpublic 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");}@Testpublic void testFindAll() {List<Person> list = mongoDBHelper.findAll(Person.class);for (Person person : list) {System.out.println("name=" + person.getName() + ",age=" + person.getAge());}}@Testpublic 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@Overridepublic void test() {System.out.println("---MongoDb Test---");}}
最后,祝大家早日学有所成,拿到满意offer