java驱动bat脚本执行mysql恢复备份根据自定义mysql备份名

我有个需求,需要根据mysql备份的地址,恢复mysql数据

就是说我把sql备份了,然后需要通过java代码触发执行恢复的mysql脚本,但是需要传一个备份的路径

直接上代码

java代码如下:

public static void main(String[] args) {
        try {
            // 指定脚本的路径
            String scriptPath = "C:\\Users\\Administrator\\Desktop\\Debug\\restoreData.bat";
            // 备份文件名作为参数传入
            String backupFileName = "C:\\Users\\Administrator\\Desktop\\12312312312\\" + "test_backup123" + ".sql";

            // 创建ProcessBuilder对象,并设置脚本路径和备份文件名作为参数
            ProcessBuilder processBuilder = new ProcessBuilder(scriptPath, backupFileName);

            // 启动进程
            Process process = processBuilder.start();

            // 读取进程的输出
            BufferedReader reader = new BufferedReader(new InputStreamReader(process.getInputStream()));
            String line;
            while ((line = reader.readLine()) != null) {
                System.out.println(line);
            }

            // 等待进程执行完毕
            int exitCode = process.waitFor();

            // 打印进程的退出码
            System.out.println("Script executed with exit code: " + exitCode);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

bat脚本如下:起名叫restoreData.bat

@echo off
rem 检查是否传递了备份文件名作为参数
if "%~1"=="" (
    echo No backup file name provided.
    exit /b 1
)

rem 设置备份文件名为传入的第一个参数
set backupFileName=%~1

rem 执行数据库备份命令,使用传入的备份文件名
D:\mysql-8.0.35-winx64\bin\mysql -uroot -p123456 -P 3306 test < "%backupFileName%"

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值