前言

  • MongoDB是一个基于分布式文件存储的开源数据库系统,使用C++语言编写。它是一个介于关系数据库和非关系数据库之间的产品,具有类似关系数据库的功能,但又有一些非关系数据库的特点。MongoDB的数据模型比较松散,采用类似json的bson格式,可以灵活地存储各种类型的数据

MongoDB的优点

  • 高性能MongoDB使用C++编写,具有高效的I/O处理能力和磁盘读写速度,能够在高并发的情况下处理大量数据请求

  • 可扩展性MongoDB采用分布式文件存储,可以方便地进行水平扩展,增加服务器数量即可提高整体性能和容量

  • 易用性MongoDB提供了丰富的编程语言驱动程序,包括Java、Python、PHP、C#等,使得开发人员可以方便地使用MongoDB进行数据存储和查询

  • 灵活性MongoDB支持的数据结构非常松散,可以灵活地存储各种类型的数据,包括文档、图片、视频等,满足不同应用的需求

MongoDB的缺点

  • 事务支持不足MongoDB在早期版本中并没有完全支持事务,这使得在处理一些需要事务保证的业务时存在局限性。虽然最新版本已经支持事务,但与传统的关系型数据库相比,事务支持仍然不足

  • 数据安全性MongoDB的数据安全性相对较低,尤其是在多节点环境中,数据的一致性难以得到保证。此外,MongoDB没有内置的数据备份和恢复机制,需要手动进行备份和恢复操作

  • 适用场景有限MongoDB适用于存储大量数据和高并发的场景,但在一些需要精确查询和复杂逻辑处理的场景中,MongoDB可能无法满足需求。在这种情况下,传统的关系型数据库可能更为适用

MongoDB应用场景MongoDB被广泛应用于各种场景,比较典型的应用包括

  • Web应用MongoDB适合用于Web应用的数据存储,尤其是对于需要处理大量用户请求和高并发的场景,例如社交网络、电商网站等

  • 日志和监控数据MongoDB可以高效地存储大量的日志和监控数据,支持水平扩展和高并发写入,方便开发人员进行分析和监控

  • 缓存MongoDB可以作为缓存层使用,将常用数据存储在MongoDB中,以提高查询效率。同时,MongoDB支持数据的过期时间和LRU缓存策略,可以有效地管理缓存生命周期

  • 文档存储MongoDB适合存储结构化和半结构化的文档数据,例如邮件、文档、图片等,可以方便地进行读取和搜索操作

Spring boot配置使用mongodb

新建一个spring boot工程,工程目录如下

配置连接池,mongodb配置前缀需要加上mongodb

spring:
data:
mongodb:
uri: mongodb://localhost:27017/test

entity字段

@Data
@Document(collection = "user") //指定要对应的文档名(表名)
@Accessors(chain = true)
public class User {
@Id
private String id;//用户ID private String name; //用户名称
}

使用mongodb实现简单的用户增删改查功能

备注:这里为了处理数据方便,就直接返回mongodb返回的数据格式了,并且处理成字符串格式,

实际的开发业务场景需要根据项目需要去处理

使用insert方法新增
@Override
public String insertUser(User user) {
User userInfo = mongoTemplate.insert(user);
return userInfo.toString();
}
使用findAll方法查询user集合
@Override
public String queryUser() {
List<User> userList = mongoTemplate.findAll(User.class,"user");
return userList.toString();
}
使用updateFirst方法更新查询到的第一个用户的信息
@Override
public String updateUser(User user) {
Update update = new Update();
update.set("name",user.getName());
mongoTemplate.updateFirst(Query.query(Criteria.where("id").is(user.getId())),update,User.class);
User userinfo = mongoTemplate.findById(user.getId().toString(),User.class);
return userinfo.toString();
}
使用remove方法删除用户信息
@Override
public String deleteUser(User user) {
mongoTemplate.remove(Query.query(Criteria.where("id").is(user.getId())),User.class);
return "删除用户成功";
}

结尾

以上spring boot配置使用mongodb的的例子,复习了一下,需要入门的同学可以参照这个例子,源码在这

源码链接

文章个人博客地址:

spring boot配置使用mongodb

创作不易,转载请注明出处和作者。

欢迎关注公众号:程序员布欧,不定期更新技术入门文章

2023年了,复习了一下spring boot配置使用mongodb的更多相关文章

  1. Spring Boot -- 配置切换指南

    一般在一个项目中,总是会有好多个环境.比如: 开发环境 -> 测试环境 -> 预发布环境 -> 生产环境 每个环境上的配置文件总是不一样的,甚至开发环境中每个开发者的环境可能也会有一 ...

  2. Spring Boot 配置优先级顺序

    一般在一个项目中,总是会有好多个环境.比如: 开发环境 -> 测试环境 -> 预发布环境 -> 生产环境 每个环境上的配置文件总是不一样的,甚至开发环境中每个开发者的环境可能也会有一 ...

  3. spring boot 配置注入

    spring boot配置注入有变量方式和类方式(参见:<spring boot 自定义配置属性的各种方式>),变量中又要注意静态变量的注入(参见:spring boot 给静态变量注入值 ...

  4. Spring boot配置多个Redis数据源操作实例

    原文:https://www.jianshu.com/p/c79b65b253fa Spring boot配置多个Redis数据源操作实例 在SpringBoot是项目中整合了两个Redis的操作实例 ...

  5. Spring Boot中使用MongoDB数据库

    前段时间分享了关于Spring Boot中使用Redis的文章,除了Redis之后,我们在互联网产品中还经常会用到另外一款著名的NoSQL数据库MongoDB. 下面就来简单介绍一下MongoDB,并 ...

  6. spring boot配置springMVC拦截器

    spring boot通过配置springMVC拦截器 配置拦截器比较简单, spring boot配置拦截器, 重写preHandle方法. 1.配置拦截器: 2重写方法 这样就实现了拦截器. 其中 ...

  7. spring boot配置mybatis和事务管理

    spring boot配置mybatis和事务管理 一.spring boot与mybatis的配置 1.首先,spring boot 配置mybatis需要的全部依赖如下: <!-- Spri ...

  8. [转] Spring Boot配置多个DataSource

    [From]  https://www.liaoxuefeng.com/article/001484212576147b1f07dc0ab9147a1a97662a0bd270c20000 Sprin ...

  9. Spring boot 配置异步处理执行器

    示例如下: 1. 新建Maven 项目 async-executor 2.pom.xml <project xmlns="http://maven.apache.org/POM/4.0 ...

  10. Spring boot配置404、500页面

    Spring boot 配置404页面很简单,如果你访问的url没有找到就会出现spring boot 提示的页面,很明显Spring boot不用配置就可以显示404页面了. 在template下创 ...

随机推荐

  1. The content of element type “web-app“ must match 解决方法

    报错原因 ‍ 问题描述 : 在创建 SpringMVC 时 , 选用 idea 的 webapp 模板来创建 , xml 配置文件中进行配置时发现提示警告 警告如下: ‍ ​ ​ 这错误大概的意思就是 ...

  2. 利用生成式预训练Transformer实现智能问答与人机交互

    目录 利用生成式预训练Transformer实现智能问答与人机交互 随着人工智能技术的不断发展,智能问答和人机交互已经成为了人工智能领域中的重要研究方向.在智能问答中,机器能够以自然的方式与人类进行对 ...

  3. 编译器性能调优:使用C++11实现高效编译器

    目录 1. 引言 2. 技术原理及概念 2.1. 基本概念解释 2.2. 技术原理介绍 <编译器性能调优:使用C++11实现高效编译器> 编译器是计算机程序的入口点,将源代码转换为可执行文 ...

  4. React后台管理系统(TypeScript、Redux状态管理)环境搭建01

      搭建环境的时候,我们必须要先确保环境有node环境和npm环境,如下使用cmd命令 确保自己有了这两个环境之后我们就可以开始搭建项目,首先找一个文件夹,这个文件夹用来初始化当前环境,例如,我这里选 ...

  5. 续《基于C# 开发的SOL SERVER 操作数据库类(SQLHelp》 ——第二弹

    续上一节,本节给出SQLHelp的具体实现方法--<YSFSQLHelp>,个人根据自己需要新建适合的类,本节根据参考网上资料,根据自己的需要编写的SQL帮助类.下面直接给出具体实现: / ...

  6. SQL Server 数据库字符串分割函数

    SQL Server 数据库字符串分割函数,源代码如下: ALTER FUNCTION [dbo].[f_split] ( @SourceStr VARCHAR(MAX), -- 源字符串 @Spli ...

  7. 处理.git文件夹过大出现臃肿问题-filter-branch和BFG工具

    Git开发手册 git一些不常用的命令记不住,可以查看git开发手册(https://m.php.cn/manual/view/34957.html) 1..git/objects/pack 文件过大 ...

  8. 进程相关API

    ID与句柄 如果我们成功创建一个进程,CreateProcess函数会给我们返回一个结构体,包括四个数 据:进程编号(ID).进程句柄.线程编号(ID).线程句柄. 进程ID其实我们早见过了,通常我们 ...

  9. k8s+containerd安装

    准备环境 准备两台服务器节点,如果需要安装虚拟机,可以参考<wmware和centos安装过程> 机器名 IP 角色 CPU 内存 centos01 192.168.109.130 mas ...

  10. 使用sqlplus

    1. 执行一个SQL脚本文件 SQL>start file_name SQL>@ file_name 可以将多条sql语句保存在一个文本文件中,这样当要执行这个文件中的所有的sql语句时, ...