我的远程数据库是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编码,但是它对我有用.