从MySQL数据库插入mdb

时间:2017-10-03 16:05:32

标签: java mysql jdbc ucanaccess

我正在尝试使用具有多个具有相同名称的表的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';");

1 个答案:

答案 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();
    }
}