You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
78 lines
2.9 KiB
78 lines
2.9 KiB
package de.memtext.db; |
|
|
|
import java.sql.DriverManager; |
|
import java.sql.SQLException; |
|
import java.util.Iterator; |
|
import java.util.List; |
|
|
|
import de.memtext.util.StringUtils; |
|
|
|
public class DBComparison { |
|
|
|
private DBComparison() { |
|
super(); |
|
} |
|
|
|
public static void main(String a[]) { |
|
try { |
|
Class.forName("org.hsqldb.jdbcDriver"); |
|
|
|
java.sql.Connection con = DriverManager.getConnection("jdbc:hsqldb:hsql://localhost:9000", "sa", ""); |
|
DBAccess.addConnection("ssc", con); |
|
java.sql.Connection con2 = DriverManager.getConnection("jdbc:hsqldb:hsql://localhost:9500", "sa", ""); |
|
DBAccess.addConnection("ssc-test", con2); |
|
compare("ssc", "ssc-test"); |
|
|
|
} catch (ClassNotFoundException e) { |
|
e.printStackTrace(); |
|
} catch (SQLException e) { |
|
e.printStackTrace(); |
|
} catch (Exception e) { |
|
e.printStackTrace(); |
|
} |
|
|
|
} |
|
|
|
private static void compare(String db1, String db2) throws SQLException { |
|
System.out.println("Start comparing..."); |
|
StringBuffer fineTables = new StringBuffer("The following tables are fine: "); |
|
List tableList = DBAccess.get(db1).getTableList(); |
|
boolean isOk = false; |
|
for (Iterator it = tableList.iterator(); it.hasNext();) { |
|
String table = (String) it.next(); |
|
|
|
if (DBAccess.get(db2).hasTable(table)) { |
|
isOk = true; |
|
if (DBAccess.get(db1).getColumnCount(table) != DBAccess.get(db2).getColumnCount(table)) { |
|
System.out.println("Table " + table + " has a different number of columns"); |
|
isOk = false; |
|
} else { |
|
List colList = DBAccess.get(db1).getColumnNames(table); |
|
for (Iterator it2 = colList.iterator(); it2.hasNext();) { |
|
String colname = (String) it2.next(); |
|
if (!DBAccess.get(db2).hasColumn(table, colname)) { |
|
System.out.println("Table " + table + " in " + db2 + " doesn't have column:" + colname); |
|
isOk = false; |
|
} else { |
|
|
|
if (DBAccess.get(db1).getColumnType(table, colname) != DBAccess.get(db2).getColumnType(table, colname)) { |
|
System.out.println("Table " + table + " column:" + colname + " are of different types"); |
|
isOk = false; |
|
} |
|
|
|
} |
|
} |
|
if (isOk) fineTables.append(table + ","); |
|
} |
|
|
|
} else { |
|
System.out.println(db2 + " doesn't contain table:" + table); |
|
} |
|
} |
|
StringUtils.deleteLastChar(fineTables); |
|
System.out.println(fineTables); |
|
System.out.println("..done"); |
|
} |
|
} |
|
|
|
//Created on 11.02.2004 at 13:19:36
|