学习mongoDb到SpringBoot整合看这一篇就足够了

news2024/9/29 5:27:54

MongoDB

简介

MongoDB 是什么:

MongoDB是一个基于文档的NoSQL数据库,用于处理大量的数据,并提供高性能、高可用性和易扩展性。相对于传统的关系型数据库,MongoDB采用文档的方式存储数据,每个文档是一组键值对的集合,类似于JSON格式。

基本概念:

  • 文档(document): MongoDB中数据的基本单元,类似于关系数据库中的行。文档是由键值对组成的。
  • .集合(collection): 一组文档的集合,类似于关系数据库中的表。
  • 数据库(database): 包含一个或多个集合,是数据的物理容器就是关系型数据库的库。

业务场景

MongoDB通常在需要处理大量非结构化或半结构化数据,并且对数据的高度伸缩性和灵活性有要求的场景下发挥作用。虽然MySQL更适合于结构化数据、支持事务和复杂查询的场景,Redis则擅长处理对速度和实时性要求极高的缓存需求,但MongoDB在以下业务场景中可能更为适用:

  1. 大数据量/非结构化数据的存储:MongoDB适合存储大量非结构化或半结构化数据,如日志、文档、JSON格式的数据等。它支持灵活的数据模型,可以轻松地存储各种不同格式的数据。
  2. 实时数据分析和处理:对于需要进行实时数据分析和处理的场景,MongoDB的分布式架构和高性能使其成为一个不错的选择。它能够快速存储和查询数据,支持复杂的聚合操作。
  3. 大规模的写入和读取操作:如果系统需要大规模的写入和读取操作,MongoDB的分布式架构和横向扩展能力可以有效地处理这种负载。
  4. 无固定模式的数据集合:相比于传统的关系型数据库,MongoDB更加灵活,不要求严格的固定模式。这使得它在面对数据模式经常变化或不确定的情况下更为适用。
  5. 地理空间和位置数据:MongoDB对地理空间和位置数据有着很好的支持,这对于需要处理地理位置信息或空间数据的应用场景非常有用,比如地图应用、位置服务等。

下面是实际开发中的场景

数据库:MySQL

用户信息存储(MySQL)

场景:用户信息通常包含结构化数据,例如用户名、密码、电子邮件等。这些信息需要持久性存储和支持复杂的查询操作。因此,用户账户信息可以存储在MySQL中。

CREATE TABLE users (
    user_id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(255) NOT NULL,
    password VARCHAR(255) NOT NULL,
    email VARCHAR(255) NOT NULL,
    -- 其他用户相关信息
);
数据库:Redis

.会话缓存(Redis):

场景:为了提高性能,可以使用Redis来缓存用户会话信息。当用户登录后,将其会话信息存储在Redis中,以便快速访问,避免每次请求都访问MySQL数据库。

伪代码示例 存储用户会话信息到Redis

redis.set("session:user_id", "session_data", expiration_time)

从Redis中获取用户会话信息

session_data = redis.get("session:user_id")
数据库:MongoDB

产品信息和日志(MongoDB):

场景:电子商务应用通常有大量的产品信息,其中一些可能是半结构化的,例如产品描述、评论等。MongoDB适合存储这种类型的数据。同时,可以使用MongoDB存储日志信息,如用户活动日志、交易日志等。

// 伪代码示例
// 存储产品信息到MongoDB

db.products.insert({
    product_id: 1,
    name: "Product Name",
    description: "Product Description",
    price: 29.99,
    // 其他产品相关信息
});

// 存储用户活动日志到MongoDB

db.user_activity.insert({
    user_id: 123,
    action: "purchase",
    product_id: 1,
    timestamp: new Date(),
    // 其他日志信息
});

这只是一个简单的示例,实际应用可能更为复杂。在开发中,数据库的选择通常取决于具体的业务需求、性能要求和数据特征。这样的组合允许开发人员充分发挥各数据库的优势,以满足不同方面的需求。

安装

我这里采用docker进行安装,(环境统一,易于维护)
拉取镜像,如果不会docekr快速入门

docker pull mongo

创建容器


docker run -di --name mongo --restart=always -p 27017:27017 -v ~/data/mongodata:/data mongo

基础操作(Shell)

连接数据库:
在MongoDB中,使用MongoDB Shell连接数据库,可以通过以下命令:

mongo

6.0以上

mongosh

在这里插入图片描述

基本 CRUD 操作(Shell):

创建(Create):

向集合中插入文档。
db.collectionName.insertOne({ key: value }); // 单个文档插入
db.collectionName.insertMany([{ key1: value1 }, { key2: value2 }]); // 多个文档插入
在这里插入图片描述
此时已经是创建好了,当尝试向一个不存在的集合(collection)写入文档(document)时,MongoDB 会自动创建这个集合。这是MongoDB的一种特性,它与传统的关系型数据库系统(如MySQL或PostgreSQL)有所不同,在传统的关系型数据库中,您必须先显式地创建表格。这个可以隐式创建集合(表)
在这里插入图片描述
并且插入的文档数据不会受到约束,字段可以不同
在这里插入图片描述
表结构也会随着
在这里插入图片描述

读取(Read):

查询集合中的文档。

db.collectionName.find();  // 查询集合中的所有文档
db.collectionName.findOne({ key: value });  // 查询符合条件的第一个文档
更新(Update):

更新集合中的文档。

db.collectionName.updateOne({ filterKey: filterValue }, { $set: { updateKey: updateValue } });
db.collectionName.updateMany({ filterKey: filterValue }, { $set: { updateKey: updateValue } });
删除(Delete):

从集合中删除文档。

db.collectionName.deleteOne({ key: value });  // 删除符合条件的第一个文档
db.collectionName.deleteMany({ key: value });  // 删除符合条件的多个文档

Springboot整合mongdb

环境安装

第一:导入mongo依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

第二:mongo yaml配置

server:
  port: 9998
spring:
  data:
    mongodb:
    #服务器地址
      host: 192.168.200.130 
      port: 27017
      #聊天记录,数据库比较大
      database: chart-history

第三使用@Autowerd来自动装配MongoTemplate使用

基础操作

创建新增文档,创建集合

因为mongodb对于数据字段是弱约束,插入文档到一张表,哪个表不存在的话就会自动创建

 @Autowired
    private MongoTemplate mongoTemplate;

    //保存
    @Test
    public void saveTest(){

        //这种方式创建集合 并且插入文档
        MongoCollection<org.bson.Document> mongoCollection = mongoTemplate.createCollection("mycollection");
        org.bson.Document doc = new Document("name", "Alice")
                .append("age", 30)
                .append("city", "New York");
        mongoCollection.insertOne(doc);

//第二种方式数据 使用注解指定文档类型
        Book book = new Book();
        book.setAuthor("Alice");
        book.setName("MongoDB in Action");
        book.setPrice(100);
   mongoTemplate.save(book);
   }

book指定的文档映射类

@Data
//类似mysql的映射表
@Document("ap_books")
public class Book {
    private  String name;
    private  String id;
    private  String author;
    private  Integer price;
    }

创建成功
在这里插入图片描述

推荐第二种方式插入表

这种方法使用了MongoTemplate的save方法来保存一个Java对象(在您的示例中是Book类的实例)。MongoTemplate会自动将POJO对象转换成MongoDB的文档格式。
这种方式更加符合Spring框架的风格,使得代码更简洁,更易于维护。

查找
//查询一个
@Test
public void saveFindOne(){
    ApAssociateWords apAssociateWords = mongoTemplate.findById("6581959dd324155de3434686", ApAssociateWords.class);
    System.out.println(apAssociateWords);
}
条件查询
@Test
public void testQuery(){
    Query query = Query.query(Criteria.where("associateWords").is("模糊查询匹配的字段"))
            .with(Sort.by(Sort.Direction.DESC,"createdTime"));

    List<ApAssociateWords> apAssociateWordsList = mongoTemplate.find(query, ApAssociateWords.class);
    System.out.println(apAssociateWordsList);
}
修改
Query query = new Query(Criteria.where("name").is("John"));
Update update = new Update().set("age", 31);

mongoTemplate.updateFirst(query, update, Person.class, "personCollection");

还是推荐直接删除在添加

删除
   @Test
    public void testDel(){
        mongoTemplate.remove(Query.query(Criteria.where("associateWords").is("匹配")),ApAssociateWords.class);
    }

高级查询

需要使用到query以及Criteria构建条件
构建查询条件。

Query query = new Query(Criteria.where("key").regex("regexPattern"));
List <YourObject> results = mongoTemplate.find(query, YourObject.class);
分页和排序:

对结果进行分页和排序。

Query query = new Query().with(Sort.by(Sort.Direction.DESC, "field")).skip(10).limit(5);//类似sql语句 from (current-1)*pageSize  limit size  
List<YourObject> results = mongoTemplate.find(query, YourObject.class);

复杂条件查询:

使用 Criteria 构建复杂的查询条件。

Criteria criteria = new Criteria().andOperator(
    Criteria.where("key1").is("value1"),
    Criteria.where("key2").gte(20)
);
Query query = new Query(criteria);
List<YourObject> results = mongoTemplate.find(query, YourObject.class);
and连接多条件
Query query = new Query(Criteria.where("age").gte(25).and("city").is("New York"));
List<Person> persons = mongoTemplate.find(query, Person.class, "personCollection");
正则表达式(模糊查询)
Criteria criteria = Criteria.where("name").regex("^J");
聚合操作:

使用聚合框架进行高级数据处理。
计数

Query query = new Query(Criteria.where("age").gte(25));
long count = mongoTemplate.count(query, "personCollection");
大于或者小于
Query query = new Query(Criteria.where("age").gte(25).lte(35));
List<Person> persons = mongoTemplate.find(query, Person.class, "personCollection");
参数是否存在,动态查询
Query query = new Query(Criteria.where("email").exists(true));//dto.getemali==null等标段式
List<Person> persons = mongoTemplate.find(query, Person.class, "personCollection");

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1333739.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

自我学习--关于如何设计光耦电路

本人在项目中多次设计光耦电路&#xff0c;目前电路在项目中运行比较平稳&#xff0c;所以总结一下自己的设计经验&#xff0c;与大家交流一下&#xff0c;如有错误还希望大家指出改正&#xff0c;谢谢&#xff08;V&#xff1a;Smt15921588263&#xff1b;愿与大家多交流&…

智能优化算法应用:基于战争策略算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于战争策略算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于战争策略算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.战争策略算法4.实验参数设定5.算法结果6.…

redis的主从复制和哨兵模式

redis的集群&#xff1a; 高可用方案&#xff1a; 持久化高可用 主从复制 哨兵模式 集群 主从复制&#xff1a;主从复制是redis实现高可用的基础&#xff0c;哨兵模式和集群都是在主从复制的基础之上实现高可用。 主从复制实现数据的多机备份&#xff0c;以及读写分离(主…

关于Python里xlwings库对Excel表格的操作(十七)

这篇小笔记主要记录如何【获取和设置单元格行高、列宽】。 前面的小笔记已整理成目录&#xff0c;可点链接去目录寻找所需更方便。 【目录部分内容如下】【点击此处可进入目录】 &#xff08;1&#xff09;如何安装导入xlwings库&#xff1b; &#xff08;2&#xff09;如何在W…

基于flask和echarts的新冠疫情实时监控系统源码+数据库,后端基于python的flask框架,前端主要是echarts

介绍 基于flask和echarts的新冠疫情实时监控系统 软件架构 后端基于python的flask框架&#xff0c;前端主要是echarts 安装教程 下载到本地&#xff0c;在python相应环境下运行app.py,flask项目部署请自行完成 使用说明 flaskProject文件夹中 app.py是flask项目主运行文…

BUG记录 | 使用阿里云OSS实现文件上传后,得到的url无法在浏览器中打开

项目背景 SpringBoot的项目&#xff0c;使用阿里云对象存储OSS对项目中的文件进行存储&#xff0c;所需文件也会通过IDEA中由官方Demo改编而成的工具类作为接口&#xff0c;调用接口后上传 问题描述 使用阿里云OSS实现文件上传后&#xff0c;通过postman测试得到的url无法在…

C# Onnx Yolov8 Detect yolov8n、yolov8s、yolov8m、yolov8l、yolov8x 对比

目录 效果 yolov8n yolov8s yolov8m yolov8l yolov8x 模型信息 项目 代码 下载 C# Onnx Yolov8 Detect yolov8n、yolov8s、yolov8m、yolov8l、yolov8x 对比 效果 yolov8n yolov8s yolov8m yolov8l yolov8x 模型信息 Model Properties ------------------------- d…

ubuntu22.04 下载路径

ftp下载路径 csdn下载 ubuntu22.04下载路径ubuntu-22.04-desktop-amd64.7z.001资源-CSDN文库 ubuntu22.04下载路径ubuntu-22.04-desktop-amd64.7z.002资源-CSDN文库 【免费】ubuntu-22.04-desktop-amd64.7z.003资源-CSDN文库 【免费】ubuntu-22.04-desktop-amd64.7z.004资源-…

Python 数据分析 Matplotlib篇 时间序列数据绘制折线图(第4讲)

Python 数据分析 Matplotlib篇 时间序列数据绘制折线图(第4讲)         🍹博主 侯小啾 感谢您的支持与信赖。☀️ 🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹…

【二叉树】【单调双向队列】LeetCode239:滑动窗口最大值

作者推荐 map|动态规划|单调栈|LeetCode975:奇偶跳 涉及知识点 单调双向队列 二叉树 题目 给你一个整数数组 nums&#xff0c;有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。你只可以看到在滑动窗口内的 k 个数字。滑动窗口每次只向右移动一位。 返回 滑动…

【GitHub精选项目】抖音/ TikTok 视频下载:TikTokDownloader 操作指南

前言 本文为大家带来的是 JoeanAmier 开发的 TikTokDownloader 项目&#xff0c;这是一个高效的下载 抖音/ TikTok 视频的开源工具。特别适合用户们保存他们喜欢的视频或分享给其他人。 TikTokDownloader 是一个专门设计用于下载 TikTok 视频的工具&#xff0c;旨在为用户提供一…

学习C语言可以从以下几个方面入手

学习C语言可以从以下几个方面入手&#xff1a; 了解基础知识&#xff1a;首先&#xff0c;你需要了解C语言的基本语法和规则&#xff0c;包括变量、数据类型、运算符、控制结构等。可以通过阅读相关的教材或在线教程来学习这些基础知识。动手实践&#xff1a;理论知识的学习是…

大数据应用开发1——配置基础环境

一、基础环境配置 1.配置虚拟网络 1.1、点击1、编辑2和3&#xff0c; 1.2、点开4&#xff0c;编辑网关 2、配置虚拟机环境 1.1、安装一台虚拟机&#xff0c;使用root用户登录&#xff0c;打开终端 1.2修改主机名 终端输入&#xff1a; vim /etc/hostname使用vim编辑/etc/ho…

linux异步IO的几种方法及重点案例

异步IO的方法 在Linux下&#xff0c;有几种常见的异步I/O&#xff08;Asynchronous I/O&#xff09;机制可供选择。以下是其中一些主要的异步I/O机制&#xff1a; POSIX AIO&#xff08;Asynchronous I/O&#xff09;&#xff1a;POSIX AIO是一种标准的异步I/O机制&#xff0c…

自动驾驶学习笔记(二十二)——自动泊车算法

#Apollo开发者# 学习课程的传送门如下&#xff0c;当您也准备学习自动驾驶时&#xff0c;可以和我一同前往&#xff1a; 《自动驾驶新人之旅》免费课程—> 传送门 《Apollo开放平台9.0专项技术公开课》免费报名—>传送门 文章目录 前言 感知算法 定位算法 规划算法…

可靠度理论中“设计基准期”、“设计使用年限”、“使用寿命”几个概念的区分

文章目录 0. 背景1. 重现期2. 设计基准期3. 设计使用年限调整系数4. 一把杆秤5. 调整系数的补充说明Last 0. 背景 在可靠度理论中&#xff0c;经常遇见“设计基准期”、“设计使用年限”、“使用寿命”几个概念。这些概念搞不清楚对于梳理结构荷载组合而言就是致命的。本文也是…

关联规则+聚类分析+分类算法(数据挖掘)

3.关联规则 经典案例 : 尿布与啤酒的故事&#xff1b; 基本概念 : 设I {i1,i2,....im}是项(Item)的集合。 D 是 事务(transaction)的集合(事务数据库)。 事务T是项的集合&#xff0c;且对每个事务具有唯一的标识: 事务号&#xff0c;记作TID; 设A是I中的一个项集&#xf…

恶意软件分析沙箱在网络安全策略中处于什么位置?

恶意软件分析沙箱提供了一种全面的恶意软件分析方法&#xff0c;包括静态和动态技术。这种全面的评估可以更全面地了解恶意软件的功能和潜在影响。然而&#xff0c;许多组织在确定在其安全基础设施中实施沙箱的最有效方法方面面临挑战。让我们看一下可以有效利用沙盒解决方案的…

【动态规划】11简单多状态 dp 问题_按摩师_C++(easy)

题目链接&#xff1a;leetcode按摩师 目录 题目解析&#xff1a; 算法原理 1.状态表示 2.状态转移方程 3.初始化 4.填表顺序 5.返回值 编写代码 题目解析&#xff1a; 题目让我们求按摩师找到最优的预约集合&#xff08;总预约时间最长&#xff09; 由题可得&#xff…

Java - 工厂设计模式

Java - 工厂设计模式 一. 简介二. 例子2.1 定义抽象类2.2 定义子类2.3 创建工厂2.4 测试 三. JDK中使用工厂模式的案例 前言 这是我在这个网站整理的笔记,有错误的地方请指出&#xff0c;关注我&#xff0c;接下来还会持续更新。 作者&#xff1a;神的孩子都在歌唱 工厂设计模式…