2017-10-12 14 views
0

私はEclipse、SQLiteデータベース、およびHibernateを使用しています。私は自分のプロジェクトでSchemaCrawlerを使いたい、すでにsqlite-jdbcライブラリを持っている。私の目的は、2つのデータベースのSchemaCrawler構造を使用して比較することです。しかし、私は最初のデータベースに接続することすらできません。私はこのコードを使用しています:SchemaCrawlerにはどのJARファイルが必要ですか?

public class SchemaConroller { 

    public SchemaConroller() { 

     SchemaCrawlerOptions options = new SchemaCrawlerOptions(); 
     options.setSchemaInfoLevel(SchemaInfoLevelBuilder.standard()); 


     try { 
      Connection conn = getConnection(); 
      Catalog catalog = SchemaCrawlerUtility.getCatalog(conn, options); 
      for (Schema schema : catalog.getSchemas()) { 
       System.out.println(schema); 
       for (Table table : catalog.getTables(schema)) { 
        System.out.print("o--> " + table); 
        for (Column column : table.getColumns()) { 
         System.out.println("  o--> " + column); 
        } 
       } 
      } 
     } catch (Exception e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
    } 

    private static Connection getConnection() throws SchemaCrawlerException, SQLException, ClassNotFoundException { 
     String dbPath = "src/home/accounting/DB/myDatabase.sqlite"; 
     Class.forName("org.sqlite.JDBC"); 
     Connection c = DriverManager.getConnection("jdbc:sqlite:" + dbPath); 
     return c; 
    } 
} 

私は常にエラーを取得:

Oct 12, 2017 1:31:50 PM schemacrawler.utility.SchemaCrawlerUtility matchDatabaseSpecificOverrideOptions 
INFO: Using database plugin for 
Oct 12, 2017 1:31:50 PM schemacrawler.utility.TypeMap <init> 
WARNING: Could not obtain data type map from connection 
java.lang.NullPointerException 
    at org.sqlite.jdbc3.JDBC3Connection.getTypeMap(JDBC3Connection.java:90) 
    at schemacrawler.utility.TypeMap.<init>(TypeMap.java:116) 
    at schemacrawler.crawl.RetrieverConnection.<init>(RetrieverConnection.java:194) 
    at schemacrawler.crawl.SchemaCrawler.crawl(SchemaCrawler.java:870) 
    at schemacrawler.utility.SchemaCrawlerUtility.getCatalog(SchemaCrawlerUtility.java:75) 
    at home.accounting.controller.SchemaConroller.<init>(SchemaConroller.java:35) 
    at home.accounting.DA.DBCheck.start(DBCheck.java:44) 
    at home.accounting.MainApp.start(MainApp.java:83) 
    at com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$162(LauncherImpl.java:863) 
    at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$175(PlatformImpl.java:326) 
    at com.sun.javafx.application.PlatformImpl.lambda$null$173(PlatformImpl.java:295) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at com.sun.javafx.application.PlatformImpl.lambda$runLater$174(PlatformImpl.java:294) 
    at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95) 
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method) 
    at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191) 
    at java.lang.Thread.run(Thread.java:748) 

私はhereからschemacrawler.jarをダウンロードしました。他のどんな瓶も同様に必要なのでしょうか?

+0

ない**文字列DBPATH = "SRC /ホーム/会計/ DB/myDatabase.sqlite" 必要な物理パス; ** –

+0

私もこの1を試してみました: '最後のデータソースのdataSource =新しいDatabaseConnectionOptions( "jdbc:sqlite:src/home/accounting/DB/myDatabase.sqlite"); \t \t戻り値dataSource.getConnection( "brunduk"、 "brunduk"); '違いはありません。 – Alyona

答えて

1

Alyonaでは、あなたの質問に投稿したログの警告を無視することができます。 sqlite-jdbc jarはJDBC標準に完全に準拠していないため、そのjarのバージョンを非常に特定する必要があります。 SchemaCrawler distributionでのみ利用可能なバージョン3.7.8を使用してください。また、使用しているSchemaCrawlerのバージョンに対応するschemacrawler-sqlite jarが必要です。

Sualeh Fatehi、SchemaCrawler

+0

SchemaCrawler 14.16.04と互換性がありますか、以前のバージョンのSchemaCrawlerに切り替えることはできますか? – Alyona

+0

私は上記のバージョンでそれを使用しようとしましたが、私はまだ 'org.sqlite.Conn.getTypeMap(Conn.java:419)'でエラーが発生していますが、少なくとも今は動作しています!そしてそれは私のデータベース構造を私に与えます。私は私の質問https://stackoverflow.com/questions/46706970/how-to-compare-two-database-structuresにコメントを書いているが、これは全く違うことを尋ねるので、これのコピーではない。あなたはそれで私に答えることができますか?これについては、私の問題は解決されています。 – Alyona

関連する問題