Java 使用mysqldump进程错误从远程数据库备份mysql

Java 使用mysqldump进程错误从远程数据库备份mysql,java,mysql,Java,Mysql,我想备份我的远程mysql数据库。我看过很多例子,但我找不到我做错了什么的答案。我的计算机上有mysql服务器,名称不是我的远程数据库,只是想在我的计算机上创建一个sql文件来进行复制。 我的按钮操作执行代码为: try { String cs = "jdbc:mysql://db4free.net:3306/DBNAME?user=DBUSER&password=DBPASSWORD"; Class.forName("com.mysql.

我想备份我的远程mysql数据库。我看过很多例子,但我找不到我做错了什么的答案。我的计算机上有mysql服务器,名称不是我的远程数据库,只是想在我的计算机上创建一个sql文件来进行复制。 我的按钮操作执行代码为:

try {
            String cs = "jdbc:mysql://db4free.net:3306/DBNAME?user=DBUSER&password=DBPASSWORD";
            Class.forName("com.mysql.jdbc.Driver").newInstance();
            Connection connection = java.sql.DriverManager.getConnection(cs);
            String executeCmd = "";
            if (connection != null) {
                executeCmd = "mysqldump -hwww.db4free.net -u DBUSER -pDBPASSWORD DBNAME > backup.sql";
                Process runtimeProcess = Runtime.getRuntime().exec(new String[] { "cmd.exe", "/c", executeCmd });
                int processComplete = runtimeProcess.waitFor();
                if (processComplete == 0) {
                    JOptionPane.showMessageDialog(rootPane, "OK");
                } else {
                    JOptionPane.showMessageDialog(rootPane, "Didn't make a copy.");
                }
            } else {
                JOptionPane.showMessageDialog(rootPane, "Failed");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }

系统找不到指定的文件

尝试向文件添加路径

            executeCmd = "/usr/bin/mysqldump -hwww.db4free.net -u DBUSER -pDBPASSWORD DBNAME > backup.sql";

系统找不到指定的文件

尝试向文件添加路径

            executeCmd = "/usr/bin/mysqldump -hwww.db4free.net -u DBUSER -pDBPASSWORD DBNAME > backup.sql";

不,我得到错误-java.io.IOException:无法运行程序“/usr/bin/mysqldump”:CreateProcess error=2,系统找不到指定的文件您的计算机上有mysqldump吗?是否已安装?否。是否有可能只创建一个*.sql文件,而不将其放入本地mysql服务器?您必须在运行此代码的计算机上安装mysqldump。代码启动了mysqldump程序好吧,让我们检查一下我的工作PC,我有一个用于其他旧项目的工作DB,但它会抛出错误,我在上面的文章中提到过。我已经检查了我的pat(echo%PATH%),没有指向mysql/bin的路径。我已将其添加到路径中。我更新了上面的程序代码,所以现在它显示我OK。但是我在本地数据库中没有看到任何变化。为什么?我的本地数据库是否必须与远程数据库同名?否,我得到错误-java.io.IOException:无法运行程序“/usr/bin/mysqldump”:CreateProcess error=2,系统找不到指定的文件在您的计算机上有mysqldump吗?是否已安装?否。是否有可能只创建一个*.sql文件,而不将其放入本地mysql服务器?您必须在运行此代码的计算机上安装mysqldump。代码启动了mysqldump程序好吧,让我们检查一下我的工作PC,我有一个用于其他旧项目的工作DB,但它会抛出错误,我在上面的文章中提到过。我已经检查了我的pat(echo%PATH%),没有指向mysql/bin的路径。我已将其添加到路径中。我更新了上面的程序代码,所以现在它显示我OK。但是我在本地数据库中没有看到任何变化。为什么?我的本地数据库是否必须与远程数据库同名?