navicat导出sql文件按日期删除

news2025/1/17 5:37:39

navicat导出sql文件按日期删除


有个sql文件很大,数据也不是全都需要,只要测试功能,根据insert into 和所在行的日期进行判断,删除多余数据,这个代码实现删除2022,2023,和2024.10.31之前的数据,简单实现。
会过滤不是日期的哪一行,结果会多括号 懒得全局替换了。

import java.io.*;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.regex.Matcher;
import java.util.regex.Pattern;


public class SqlFilter {
    public static void main(String[] args) {
        String inputFilePath = "C:\\Users\\test\\Desktop\\a.sql";  // 输入 SQL 文件路径
        String outputFilePath = "C:\\Users\\test\\Desktop\\b.sql";  // 输出过滤后的 SQL 文件路径


        // 读取并处理文件内容
        try (BufferedReader reader = new BufferedReader(new FileReader(inputFilePath));
             BufferedWriter writer = new BufferedWriter(new FileWriter(outputFilePath))) {

            String line;
            while ((line = reader.readLine()) != null) {
                // 如果行包含 "INSERT INTO",进行日期检查
                if (line.startsWith("INSERT INTO")) {
                    // 使用正则表达式检查日期字段(假设日期格式是 'YYYY-MM-DD HH:MM:SS')
                    String filteredLine = filterInsertStatement(line);
                    // 如果该行不符合删除条件,则写入输出文件
                    if (!filteredLine.isEmpty()) {
                        writer.write(filteredLine);
                        writer.newLine();
                    }
                } else {
                    // 非INSERT INTO语句直接写入
                    writer.write(line);
                    writer.newLine();
                }
            }

            System.out.println("过滤完成,结果保存在 " + outputFilePath);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    // 过滤 INSERT INTO 语句中的日期字段,删除包含不符合条件的日期的行
    private static String filterInsertStatement(String insertStatement) {
        // 提取 VALUES 部分
        int valuesStart = insertStatement.indexOf("VALUES") + 7;
        int valuesEnd = insertStatement.indexOf(");");

        if (valuesStart == -1 || valuesEnd == -1) {
            return "";  // 无效的插入语句
        }

        String values = insertStatement.substring(valuesStart, valuesEnd).trim();

        String[] valueLines = values.split("\\),\\(");
        StringBuilder filteredValues = new StringBuilder();

        // 定义不符合条件的日期(2022, 2023, 和 2024年10月31日前)
        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String cutoffDateStr = "2024-10-31 23:59:59";
        Date cutoffDate = null;
        try {
            cutoffDate = dateFormat.parse(cutoffDateStr);
        } catch (Exception e) {
            e.printStackTrace();
        }

        for (String valueLine : valueLines) {
            // 使用正则表达式匹配日期字段(假设日期格式是 'YYYY-MM-DD HH:MM:SS')
            Pattern datePattern = Pattern.compile("'(\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2})'");
            Matcher dateMatcher = datePattern.matcher(valueLine);

            boolean containsExcludedDate = false;
            while (dateMatcher.find()) {
                String dateStr = dateMatcher.group(1);
                String year = dateStr.substring(0, 4);  // 提取年份部分
                Date currentDate = null;
                try {
                    currentDate = dateFormat.parse(dateStr);
                } catch (Exception e) {
                    e.printStackTrace();
                }

                // 判断是否符合删除条件(包含2022或2023年,或2024年10月31号之前的日期)
                if (year.equals("2023") || year.equals("2022") || (currentDate != null && currentDate.before(cutoffDate))) {
                    containsExcludedDate = true;
                    break;  // 如果找到符合条件的日期,跳出循环
                }
            }

            // 如果不包含2023、2022年,且日期不在截止日期之前,则保留该行
            if (!containsExcludedDate) {
                if (filteredValues.length() > 0) {
                    filteredValues.append(",\n");
                }
                filteredValues.append("(").append(valueLine).append(")");
            }
        }

        // 如果没有排除的日期,返回原始语句
        if (filteredValues.length() > 0) {
            return insertStatement.substring(0, valuesStart) + " " + filteredValues.toString() + " );";
        } else {
            return "";  // 如果没有有效的值,返回空字符串,表示跳过该行
        }
    }
}

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

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

相关文章

【精选】基于EfficientViT优化YOLOv8的智能车辆识别系统设计 车辆颜色分类与车牌检测、深度学习目标检测系统开发

博主介绍: ✌我是阿龙,一名专注于Java技术领域的程序员,全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师,我在计算机毕业设计开发方面积累了丰富的经验。同时,我也是掘金、华为云、阿里云、InfoQ等平台…

自动化仓储管理与库存控制

导语 大家好,我是社长,老K。专注分享智能制造和智能仓储物流等内容。欢迎大家到本文底部评论区留言。 完整版文件和更多学习资料,请球友到知识星球【智能仓储物流技术研习社】自行下载 本文是一本关于仓储管理与库存控制的教材,全…

redux 结合 @reduxjs/toolkit 的使用

1,使用步骤 使用React Toolkit 创建 counterStore(store目录下) --> 为React注入store(src下面的index) --> React组件使用store中的数据(组件) 2,例如下面有一个简单加减的…

大模型UI:Gradio全解11——Chatbot:融合大模型的聊天机器人(4)

大模型UI:Gradio全解11——Chatbot:融合大模型的聊天机器人(4) 前言本篇摘要11. Chatbot:融合大模型的多模态聊天机器人11.4 使用Blocks创建自定义聊天机器人11.4.1 简单聊天机器人演示11.4.2 流式传输Chatbot11.4.3 添…

Spring官网构建Springboot工程

注意:基于Idea的 Spring Initializr 快速构建 SpringBoot 工程时需要联网。 1.进入SpringBoot官网 Spring | Home 点击QUICKSTART 点击start.spring.io进入spring initializr 2.选择依赖 3.生成工程 下载好后解压用IDEAD导入即可。

【Hive】海量数据存储利器之Hive库原理初探

文章目录 一、背景二、数据仓库2.1 数据仓库概念2.2 数据仓库分层架构2.2.1 数仓分层思想和标准2.2.2 阿里巴巴数仓3层架构2.2.3 ETL和ELT2.2.4 为什么要分层 2.3 数据仓库特征2.3.1 面向主题性2.3.2 集成性2.3.3 非易失性2.3.4 时变性 三、hive库3.1 hive概述3.2 hive架构3.2.…

【MySQL实战】mysql_exporter+Prometheus+Grafana

要在Prometheus和Grafana中监控MySQL数据库,如下图: 可以使用mysql_exporter。 以下是一些步骤来设置和配置这个监控环境: 1. 安装和配置Prometheus: - 下载和安装Prometheus。 - 在prometheus.yml中配置MySQL通过添加以下内…

脚本化挂在物理盘、nfs、yum、pg数据库、nginx(已上传脚本)

文章目录 前言一、什么是脚本化安装二、使用步骤1.物理磁盘脚本挂载(离线)2.yum脚本化安装(离线)3.nfs脚本化安装(离线)4.pg数据库脚本化安装(离线)5.nginx脚本化安装(离…

k8s物料清单工具——KubeClarity

介绍 KubeClarity是一个用于检测和管理容器镜像和文件系统的软件清单(SBOM)和漏洞的工具。它扫描运行时的K8s集群和CI/CD流水线,以增强软件供应链安全性。 安装 添加 helm 仓库 helm repo add kubeclarity https://openclarity.github.io…

citrix netscaler13.1 重写负载均衡响应头(基础版)

在 Citrix NetScaler 13.1 中,Rewrite Actions 用于对负载均衡响应进行修改,包括替换、删除和插入 HTTP 响应头。这些操作可以通过自定义策略来完成,帮助你根据需求调整请求内容。以下是三种常见的操作: 1. Replace (替换响应头)…

Linux Centos 安装Jenkins到服务

一、前言 假设你已经下载了jenkins.war 安装了对应的jdk,下面我们来安装jenkins,以服务的形式安装。 二、安装 1)将jenkins.war拷贝到合适的位置,我的位置 /u01/jenkins/ ,位置你自己选。 2)创建系统用户…

网安——计算机网络基础

一、计算机网络概述 1、Internet网相关概念及发展 网络(Network)有若干结点(Node)和连接这些结点的链路(link)所组成,在网络中的结点可以是计算机、集线器、交换机或路由器等多个网络还可以通…

Xcode 正则表达式实现查找替换

在软件开发过程中,查找和替换文本是一项常见的任务。正则表达式(Regular Expressions)是一种强大的工具,可以帮助我们在复杂的文本中进行精确的匹配和替换。Xcode 作为一款流行的开发工具,提供了对正则表达式的支持。本…

数据结构9——二叉搜索树

🥇1.二叉搜索树的概念 二叉搜索树(Binary Search Tree,BST)又称二叉排序树或二叉查找树,其要么是一棵空树,要么具有以下性质: ①:左子树上所有节点的值都小于根节点; ②:右子树上所有节点的值都…

leetcode刷题记录(四十八)——128. 最长连续序列

(一)问题描述 128. 最长连续序列 - 力扣(LeetCode)128. 最长连续序列 - 给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。请你设计并实现时间复…

c语言——【linux】多进程编程 【进程的创建,相关shell指令,进程状态切换,回收资源,守护进程等】

1.思维导图 2.进程的创建 函数原型:pid_t fork(void); 功能描述:以当前进程为父进程,创建一个子进程 进程链和进程扇的创建 3.多进程具体使用 3.1进程替换 exec 函数一族 int execl(const char *path, const char *arg, ... /* (char *) N…

在服务器上增加新网段IP的路由配置

在服务器上增加新网段IP的路由配置 前提条件步骤一:检查当前路由表步骤二:添加新路由步骤三:验证新路由步骤四:持久化路由配置脚本示例结论在网络管理中,路由配置是一项基本且重要的任务。它决定了数据包在网络中的传输路径。本文将详细介绍如何在服务器上增加新的路由配置…

国产fpga nvme ip高速存储方案设计

国产高速存储方案主要是使用nvme ip实现高速存储方案,nvme ip采用纯verilog语言实现,用户拿到nvme ip使用起来也很简单。 先看看效果如 zu7eg板子,这个芯片支持pcie3.0 x4. zynq 7045板子只支持pcie 2.0 x4 速度测试,测试nvme …

浅谈云计算14 | 云存储技术

云存储技术 一、云计算网络存储技术基础1.1 网络存储的基本概念1.2云存储系统结构模型1.1.1 存储层1.1.2 基础管理层1.1.3 应用接口层1.1.4 访问层 1.2 网络存储技术分类 二、云计算网络存储技术特点2.1 超大规模与高可扩展性2.1.1 存储规模优势2.1.2 动态扩展机制 2.2 高可用性…

[操作系统] 深入理解约翰·冯·诺伊曼体系

约翰冯诺依曼(John von Neumann,1903年12月28日—1957年2月8日),原名诺伊曼亚诺什拉约什(Neumann Jnos Lajos),出生于匈牙利的美国籍犹太人数学家,20世纪最重要的数学家之一&#xf…