JDBC 同时连接到 MySQL 和 Sybase 数据库
JDBC connection to MySQL and Sybase database at same time
我正在尝试从 SYBASE 数据库中检索数据并将检索到的数据复制到 table 中的 MySQL 中。我能够分别连接两个数据库(即)使用 SYBASE 的 jTDS 驱动程序和 MySQL 的 Jdbc_driver。
现在我想在一个程序中同时连接两个数据库。但是我搞糊涂了 Class.forName()
.
应该写什么
我对 MySQL 使用 Class.forName(JDBC_DRIVER);
,对 SYBASE 使用 Class.forName("net.sourceforge.jtds.jdbc.Driver");
。
Sybase:
public static void main(String[] args) {
String a;
String b;
String c;
try {
Class.forName("net.sourceforge.jtds.jdbc.Driver");
Connection con = DriverManager.getConnection(
"jdbc:jtds:sybase://10.159.252.29:4100/fmdb","sa","Changeme_123");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("selecttbl_alm_log_2000000000.Csn,"
+ "tbl_alm_log_2000000000.IsCleared,"
+ "tbl_alm_log_2000000000.Id"
+ "From fmdb.dbo.tbl_alm_log_2000000000"
+ "Where IsCleared = 0");
while(rs.next()) {
a = rs.getString(1);
b = rs.getString(2);
c = rs.getString(3);
System.out.println(a+" "+b+" "+c);
}
con.close();
} catch(Exception e) {
System.out.println(e);
}
}
MySQL:
try {
Class.forName(JDBC_DRIVER);
System.out.println("connecting to database");
conn = DriverManager.getConnection(DB_URL, USER, PASS);
System.out.println("connected to database successfully");
System.out.println("creating table in given database");
// stmt = conn.createStatement();
String sql = "CREATE TABLE newtable "
+ "(id INTEGER not NULL, "
+ "first VARCHAR(255), "
+ "PRIMARY KEY ( id ))";
stmt = conn.prepareStatement(sql);
stmt.executeUpdate(sql);
System.out.println("created table in database");
}
这些只是片段。我只是想合并上面的代码。
告诉我这是否可能并分享一些对此的见解,帮助我。
建议将一个复杂的任务分成更小更简单的任务:
1) 创建方法 readDB(int startReading, int endReading)with return 作为 ResultSet
2) 创建方法 writeDB(ResultSet result)
3) 创建方法 createTableDB()
P.S。 readDB 接近你的第一个例子,必须 return 读取数据库,writeDB 只需要在数据库中写入 some tutorial,然后 createTableDB 必须像你一样在数据库上创建 table写在你的第二个例子中。
伪最终代码,在main:
createTableDB();
// it's good to make a loop for next part:
ResultSet read1=readDB(0,200);
writeDB(read1);
ResultSet read2=readDB(200,400);
writeDB(read2);
ResultSet read3=readDB(400,....); //to the end of db
writeDB(read3);
这是一个非常简单的解决方案,它并不完美,可以根据您的需要进行修改。
单个程序中的多个连接,可以这样创建
public static void main(String[] args) {
try{
Class.forName("net.sourceforge.jtds.jdbc.Driver");
Connection con1 = DriverManager.getConnection("jdbc:jtds:sybase://10.159.252.29:4100/fmdb","sa","Changeme_123");
Class.forName(JDBC_DRIVER);
Connection con2 = DriverManager.getConnection(DB_URL, USER, PASS);
///After getting both connections, write your code
String a;
String b;
String c;
Statement stmt= con1.createStatement();
ResultSet rs=stmt.executeQuery("select tbl_alm_log_2000000000.Csn, tbl_alm_log_2000000000.IsCleared, tbl_alm_log_2000000000.Id From fmdb.dbo.tbl_alm_log_2000000000 Where IsCleared = 0");
while(rs.next()) ///If your query result is single row, use if instead of while
{
a = rs.getString(1);
b = rs.getString(2);
c = rs.getString(3);
System.out.println(a+" "+b+" "+c);
}
String sql = "CREATE TABLE newtable " + "(id INTEGER not NULL, " + "first VARCHAR(255), " + "PRIMARY KEY ( id ))";
stmt = con2.prepareStatement(sql);
stmt.executeUpdate(sql);
con1.close();
con2.close();
}catch(Exception e){ System.out.println(e);}
}
}
我正在尝试从 SYBASE 数据库中检索数据并将检索到的数据复制到 table 中的 MySQL 中。我能够分别连接两个数据库(即)使用 SYBASE 的 jTDS 驱动程序和 MySQL 的 Jdbc_driver。
现在我想在一个程序中同时连接两个数据库。但是我搞糊涂了 Class.forName()
.
我对 MySQL 使用 Class.forName(JDBC_DRIVER);
,对 SYBASE 使用 Class.forName("net.sourceforge.jtds.jdbc.Driver");
。
Sybase:
public static void main(String[] args) {
String a;
String b;
String c;
try {
Class.forName("net.sourceforge.jtds.jdbc.Driver");
Connection con = DriverManager.getConnection(
"jdbc:jtds:sybase://10.159.252.29:4100/fmdb","sa","Changeme_123");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("selecttbl_alm_log_2000000000.Csn,"
+ "tbl_alm_log_2000000000.IsCleared,"
+ "tbl_alm_log_2000000000.Id"
+ "From fmdb.dbo.tbl_alm_log_2000000000"
+ "Where IsCleared = 0");
while(rs.next()) {
a = rs.getString(1);
b = rs.getString(2);
c = rs.getString(3);
System.out.println(a+" "+b+" "+c);
}
con.close();
} catch(Exception e) {
System.out.println(e);
}
}
MySQL:
try {
Class.forName(JDBC_DRIVER);
System.out.println("connecting to database");
conn = DriverManager.getConnection(DB_URL, USER, PASS);
System.out.println("connected to database successfully");
System.out.println("creating table in given database");
// stmt = conn.createStatement();
String sql = "CREATE TABLE newtable "
+ "(id INTEGER not NULL, "
+ "first VARCHAR(255), "
+ "PRIMARY KEY ( id ))";
stmt = conn.prepareStatement(sql);
stmt.executeUpdate(sql);
System.out.println("created table in database");
}
这些只是片段。我只是想合并上面的代码。 告诉我这是否可能并分享一些对此的见解,帮助我。
建议将一个复杂的任务分成更小更简单的任务:
1) 创建方法 readDB(int startReading, int endReading)with return 作为 ResultSet
2) 创建方法 writeDB(ResultSet result)
3) 创建方法 createTableDB()
P.S。 readDB 接近你的第一个例子,必须 return 读取数据库,writeDB 只需要在数据库中写入 some tutorial,然后 createTableDB 必须像你一样在数据库上创建 table写在你的第二个例子中。
伪最终代码,在main:
createTableDB();
// it's good to make a loop for next part:
ResultSet read1=readDB(0,200);
writeDB(read1);
ResultSet read2=readDB(200,400);
writeDB(read2);
ResultSet read3=readDB(400,....); //to the end of db
writeDB(read3);
这是一个非常简单的解决方案,它并不完美,可以根据您的需要进行修改。
单个程序中的多个连接,可以这样创建
public static void main(String[] args) {
try{
Class.forName("net.sourceforge.jtds.jdbc.Driver");
Connection con1 = DriverManager.getConnection("jdbc:jtds:sybase://10.159.252.29:4100/fmdb","sa","Changeme_123");
Class.forName(JDBC_DRIVER);
Connection con2 = DriverManager.getConnection(DB_URL, USER, PASS);
///After getting both connections, write your code
String a;
String b;
String c;
Statement stmt= con1.createStatement();
ResultSet rs=stmt.executeQuery("select tbl_alm_log_2000000000.Csn, tbl_alm_log_2000000000.IsCleared, tbl_alm_log_2000000000.Id From fmdb.dbo.tbl_alm_log_2000000000 Where IsCleared = 0");
while(rs.next()) ///If your query result is single row, use if instead of while
{
a = rs.getString(1);
b = rs.getString(2);
c = rs.getString(3);
System.out.println(a+" "+b+" "+c);
}
String sql = "CREATE TABLE newtable " + "(id INTEGER not NULL, " + "first VARCHAR(255), " + "PRIMARY KEY ( id ))";
stmt = con2.prepareStatement(sql);
stmt.executeUpdate(sql);
con1.close();
con2.close();
}catch(Exception e){ System.out.println(e);}
}
}