如何在Windows XP中使用Java远程连接ODBC?

我的远程数据库是Mysql数据库,我想检索一些记录并将其放入
 Microsoft Access数据库是本地主机数据库

我也想为远程数据库创建DSN

请帮我

解决方法:

我刚刚在MATLAB中进行了类似的设置,它使用java连接到MySQL和Access数据库.
我用以下方法创建了一个Java类

/**
 * Open a connection to a MySQL database
 * @param userName      registered user on the MySQL database.
 * @param userPassword  MySQL database password for the named user.
 * @param databaseUrl   database name eg. 'jdbc:mysql://glnd2818898.network.net/matlab'
 */
 public void openMySQLConnection(String userName, String userPassword, String databaseUrl){
    try {
        Class.forName ("com.mysql.jdbc.Driver").newInstance ();
        conn = DriverManager.getConnection (databaseUrl, userName, userPassword);

    }catch (SQLException e) {System.err.println ("Cannot connect to database server");}
 }

它运行在内部网络上,因此根据定义databaseUrl的注释glnd2818898.network.net是MySQL服务器,它连接到数据库’matlab’

访问界面类似

    private static final String accessDBURLPrefix = "jdbc:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ=";
    private static final String accessDBURLSuffix = ";READONLY=true}";

    /**
     * Open a connection to a Access database
     * @param userName      registered user on the Access database.
     * @param userPassword  Access database password for the named user.
     * @param databaseUrl   database name eg. 'pathname/accessName.mdb'
     */
public void openConnAccess(String userName, String userPassword, String databaseUrl){
    try {
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
                    String dbUrl = accessDBURLPrefix + databaseUrl + accessDBURLSuffix;
        conn = DriverManager.getConnection (dbUrl, userName, userPassword);
    }catch (SQLException e) {System.err.println ("Cannot connect to database server  :" + e.getMessage());}
}

从我从MATLAB用户的角度来看,这可能不是最整洁的Java编码,但是它对我有用.

上一篇:数据库访问接口(ODBC,OLEDB,ADO)


下一篇:java – 使用JDBC从Access数据库读取Unicode数据