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

网友投稿 244 2023-02-05

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

前言

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

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

一、技术介绍

1.MongoDB是什么?

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

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

二、使用步骤

1.引入maven库

代码如下(示例gGqEUHRHo):

org.springframework.boot

spring-boot-starter-parent

2.4.1

org.springframework.boot

spring-boot-starter-data-mongodb

2.具体使用示例

MongoDB封装:

/**

* mongo db助手

*

* @Author: heyuhua

* @Date: 2021/1/19 9:52

*/

@Component

public class MongoDBHelper {

@Autowired

private MongoTemplate mongoTemplate;

/**

* 保存

*

* @param t

* @param

* @return

*/

public T save(T t) {

return mongoTemplate.save(t);

}

/**

* 保存

*

* @param t

* @param collectionName

* @param

* @return

*/

public T save(T t, String collectionName) {

return mongoTemplate.save(t, collectionName);

}

/**

* 查询

*

* @param query

* @param tClass

* @param

* @return

*/

public List find(Query query, Class tClass) {

return mongoTemplate.find(query, tClass);

}

/**

* 查询所有

*

* @param tClass

* @param

* @return

*/

public List findAll(Class 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 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 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---");

}

}

总结

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

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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java并发编程之常用的辅助类详解
下一篇:公众号开发api接口(微信公众号api接口开发)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~