当前位置: 首页 > news >正文

springboot中使用Java代码进行MongoDB集合数据备份

有时候mongo的集合中数据量太大,查询或翻页时可能会超过最大数量报错,可以给mongo的集合进行备份并保留最近一段时间的数据即可
下面是通过Java代码进行mongo的集合备份单元测试


import cn.hutool.core.date.DateUtil;
import com.nuoyi.study.dao.mongo.po.BehaviorLogPo;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.mongodb.core.MongoTemplate;import java.util.Date;
import java.util.List;/*** @desc: mongo备份单元测试* @Author: nuoyi* @Date: 2023/11/7 2:39 下午*/
@SpringBootTest(classes = App.class)
@Slf4j
public class MongoBackTest {private final static String CollectionName = "NuoYi_Study_Behavior_Log";@Autowiredprivate MongoTemplate mongoTemplate;/*** mongo指定集合备份* */@Testpublic void test(){long s = System.currentTimeMillis();String targetCollectionName = CollectionName +"_"+ DateUtil.format(new Date(),"yyyy_MM");// 创建备份集合A(如果不存在)if (!mongoTemplate.collectionExists(targetCollectionName)) {mongoTemplate.createCollection(targetCollectionName);}// 获取源集合B的数据并备份到集合AList<BehaviorLogPo> documents = mongoTemplate.findAll(BehaviorLogPo.class, "NuoYi_Study_Behavior_Log");mongoTemplate.insert(documents,targetCollectionName);long e = System.currentTimeMillis();System.out.println("数据备份完成!");System.out.println("总共耗时:"+(e-s));}}

在这里插入图片描述
可以看到数据备份成功,在navicat中也能看到有125条数据

在这里插入图片描述

可配合定时器每月或每季度的凌晨备份数据并删除原集合中以往的数据,保留最近一段时间的数据即可,在生产中最好让DB或运维来操作备份数据库

http://www.lryc.cn/news/221355.html

相关文章:

  • JavaEE的渊源
  • html中使用JQ自定义锚点偏移量
  • 032、数据增广*
  • 力扣最热一百题——盛水最多的容器
  • 备份扫描工具 god_bak
  • 软考 系统架构设计师系列知识点之数字孪生体(2)
  • CSS实现文本左右对齐
  • 利用exec命令进入docker容器时的报错问题
  • Java 与C++ 语言的一些区别
  • npm ERR! network ‘proxy‘ config is set properly. See: ‘npm help config解决方法
  • An Empirical Study of Instruction-tuning Large Language Models in Chinese
  • [MICROSAR Adaptive] --- 开发环境准备
  • Yolov5 batch 推理
  • 【ARFoundation学习笔记】ARFoundation基础(下)
  • 《UML和模式应用(原书第3版)》2024新修订译本部分截图
  • JSP 学生成绩查询管理系统eclipse开发sql数据库serlvet框架bs模式java编程MVC结构
  • 技术分享 | app自动化测试(Android)-- 属性获取与断言
  • flutter实现上拉到底部加载更多数据
  • UE4 Niagara Module Script 初次使用笔记
  • 【Spring Boot 源码学习】JedisConnectionConfiguration 详解
  • 联想服务器-HTTP boot安装Linux系统
  • 容器滚动更新过程中流量无损
  • 深入理解JS中的this
  • rust 基础数据类型
  • ELK极简上手
  • 在 JavaScript 中,变量的作用域是如何确定的?
  • 常见面试题-TCP三次握手四次挥手
  • 前端框架Vue学习 ——(六)Vue组件库Element
  • 第六章:Property-based Testing and Test Oracles
  • react生命周期函数