我正在尝试使用具有多个具有相同名称的表的MySQL数据插入Access数据库
问题:我不确定应该如何建立Connections,因为我刚刚连接到一个数据库(MySQL),现在我需要连接到mdb(Access)。 我已经达到了可以使用“UCanAccess”的程度,但它有点骨头,我不确定它是否会起作用。
Class clazz = Class.forName("com.mysql.jdbc.Driver");
Class clazz2 = Class.forName("net.ucanaccess.jdbc.UcanaccessDriver");
Connection MySQL_con = DriverManager.getConnection(URL,USERNAME,PASSWORD);
Connection Acc_con = DriverManager.getConnection(URL2);
//How can I connect to Access and MySQL?
PreparedStatement pst = MySQL_con.prepareStatement(
"INSERT INTO DB2.dbo.table1
SELECT * FROM DB1.dbo.table1
WHERE DB1.table1.x='5';");
答案 0 :(得分:1)
MySQL Connector / J无法写入Access数据库,并且UCanAccess无法从MySQL数据库读取,因此您无法使用问题中所述的单个语句复制数据。相反,您将使用MySQL连接读取并使用UCanAccess连接进行写入,如下所示:
try (
Connection mysqlConn = DriverManager.getConnection(mysqlConnUrl);
Statement mysqlStmt = mysqlConn.createStatement();
ResultSet mysqlRs = mysqlStmt.executeQuery(
"SELECT client_id, last_name FROM client WHERE x = '5'");
Connection ucanaccessConn = DriverManager.getConnection(ucanaccessConnUrl);
PreparedStatement ucanaccessStmt = ucanaccessConn.prepareStatement(
"INSERT INTO client (client_id, last_name) VALUES (?, ?)")) {
while (mysqlRs.next()) {
ucanaccessStmt.setInt(1, mysqlRs.getInt(1));
ucanaccessStmt.setString(2, mysqlRs.getString(2));
ucanaccessStmt.executeUpdate();
}
}