java Runtime执行shell脚本并传递参数,完成mysql数据库表导出

本文介绍如何使用Shell脚本编写mysqldump命令,将指定的MySQL数据库导出为SQL文件,具体操作步骤及Java代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

编写导出sql文件的shell脚本,在/home/amtcloud/sql/目录下的exportsql.sh

#!/bin/sh

cd /usr/share/mysql/ (或者mysql的bin目录下,即mysqldump存在的地方)

mysqldump -h192.168.58.255 -P3306 -uroot -p123 "$1“ ”$2" > /home/amtcloud/sql/aaa.sql

 

javad代码如下:

Runtime time = Runtime.getRuntime();

    try {

/*time.exec("cd D:\\Program Files\\MySQL\\MySQL Server 5.6\\bin");

time.exec("mysqldump -h58.215.56.89 -P3306 -uroot -p123456 673680482_qq_aaa > D:\\aaa.sql");*/

    String command = “/home/amtcloud/sql/exportsql.sh”;

    //time.exec(command);

 

    String[] com = new String[]{"/bin/sh","-c","bash "+command+" databasename"+" tablename"};

   

    Process process = time.exec(com);

    BufferedReader errorReader = new BufferedReader(new InputStreamReader(  

                    process.getInputStream()));  

            String line = null;  

            while ((line = errorReader.readLine()) != null) {  

                System.err.println(line);  

            }  

            errorReader.close();  

            BufferedReader infoReader = new BufferedReader(new InputStreamReader(  

                    process.getErrorStream()));  

            while ((line = infoReader.readLine()) != null) {  

                System.out.println(line);  

            }  

            infoReader.close();   

   

} catch (IOException e) {

e.printStackTrace();

}

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值