9

我需要获取 MySQL 的安装路径,以便通过 java 代码执行导出和导入数据库。目前正在使用eclipse。我需要在字符串变量“mySqlPath”中获取安装路径。

File fMysqlPath = new File("C:\\Program Files\\MySQL\\MySQL Server 5.1\\bin\\");
String executeCmd = "mysqldump -u " + Constants.DB_USER + " -p" + 
                    Constants.DB_PASSWORD + " " + Constants.DB_NAME + " -r " + 
                    FilePath + "\\" + FileName;
Process runtimeProcess = Runtime.getRuntime().exec(executeCmd, null, fMysqlPath);

这就是我所做的。这有一个依赖问题。

我该如何解决这个问题?

4

2 回答 2

11

你有没有试过这个:

import java.sql.*;
import javax.sql.*;

public class MysqlPathFinderDemo{

public static void main(String args[]){
String dbtime;
String dbUrl = "jdbc:mysql://your.database.domain/yourDBname";
String dbClass = "com.mysql.jdbc.Driver";
String query = "Select * FROM users";

try {

      Class.forName("com.mysql.jdbc.Driver");
      Connection con = DriverManager.getConnection (dbUrl);
      Statement stmt = con.createStatement();
      res = Myconnection.st.executeQuery("select @@datadir");
      String Mysqlpath = "";

      while(res.next()){
          Mysqlpath=res.getString(1) ;
      }

      Mysqlpath = Mysqlpath.replace("Data", "bin"); 
      System.err.println("Mysql path is :"+a);
   } catch(Exception ee) {
   }
 }
}
于 2012-09-27T06:47:01.357 回答
5

你可以直接查询mysql并要求自己给你路径:

SHOW VARIABLES LIKE 'basedir';

或者更容易,

SELECT @@basedir;

应该给你安装路径。两者都应该产生类似的结果:

C:\Program Files\MySQL\MySQL 服务器 5.1\

datadir相当于获取数据目录的路径(数据所在的位置)。

于 2013-07-18T09:38:44.157 回答