从一个Mysql数据库插入另一个

时间:2014-03-19 17:18:41

标签: java mysql jdbc

我正在尝试将数据从一个mysql数据库传输到另一个。对于一个我有连接URL作为数据库名称,用户名和密码(因为这必须存在于远程位置)。另一个我正在使用数据源。

public class errorlog {
     public static void main(String[] args)
        {
            try {
              Class.forName("com.mysql.jdbc.Driver");
        System.out.println("Driver loaded mysql1server");
        Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
        System.out.println("Driver loaded mysql");

            } catch (ClassNotFoundException e) {
                // TODO Auto-generated catch block
                System.out.println("not loaded");
            }
            String connectionUrl = "jdbc:mysql//localhost:3306/db1" ;

              String connectionUrl2="jdbc:odbc:test";
                Connection con=null;
                Connection con2=null;
                Statement stmt = null;
                ResultSet rs = null;
                PreparedStatement pstmt = null;


                try {
                    con = DriverManager.getConnection(connectionUrl,"root","root");
                    System.out.println("CONNECTED1 mysql1");
                 con2 = DriverManager.getConnection(connectionUrl2);
              System.out.println("CONNECTED2 mysql");
                } catch (SQLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }


                try {
                 stmt = con.createStatement();
                 rs=stmt.executeQuery("select * FROM db1.db1_table");
                  System.out.print("Select executed");
                } catch (SQLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }


               try {
                    while (rs.next()) {

                        int col1 = rs.getInt("col1");
                        String col2=rs.getString("col2");


Date TimeStamp = rs.getDate("Time Stamp");



                    String insertSql ="Insert into db2.db2_table (`col1`,`col2`) values(?,?)";
                            pstmt = con2.prepareStatement(insertSql);

                             pstmt.setInt(1,col1);
                            pstmt.setString(2,col2);


pstmt.setDate(3,(java.sql.Date) TimeStamp);

                            pstmt.executeUpdate();




                       pstmt.close();
                       System.out.println("insert done");
                    }

                } catch (SQLException e1) {
                    // TODO Auto-generated catch block
                    e1.printStackTrace();
                }

                System.out.println("out insert done");


    }
    }

我收到错误“为jdbc找不到合适的驱动程序:mysql // localhost:3306 / databaseName = db1; user = root; password = root”

请告诉我错误的地方。

进一步要求 -

我想使用一个配置文件,它将保存一个时间值,并在获取数据时继续更新.Ex-文件保持值2014-03-18 12:00:00,程序将定期运行间隔为1小时。我想在文件保持时间后才获取数据。一旦运行,文件应该更新。

请让我知道如何做dat。

2 个答案:

答案 0 :(得分:0)

你没有加载MySQL驱动程序。你有

的ODBC驱动程序
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

但你需要一些mysql jdbc协议,例如

Class.forName("com.mysql.jdbc.Driver");

然后需要在项目中引用/包含mysql连接器jar。

答案 1 :(得分:0)

  

我收到错误“为jdbc找不到合适的驱动程序:mysql // localhost:3306 / databaseName = db1; user = root; password = root”

在mysql'

之后你需要一个冒号
相关问题