xerial sqlite-jdbc 3.7.2在OSX Mountain Lion上返回[SQLITE_NOTADB]

时间:2013-03-09 12:29:10

标签: java macos sqlite jdbc

我从iPhone的iTunes备份中提取了iOS 6 sms数据库。这是一个sqlite3 db。

当我在终端中查询它时,它工作正常:

$ sqlite3 sms.db
sqlite> select * from message;

但是当我尝试用xerial sqlite-jdbc查询它时,我得到一个[SQLITE_NOTADB]。

这是我使用的代码:

public class Sample {
    public static void main(String[] args) throws ClassNotFoundException {
        String dbFilePath = args[0];
        File dbFile = new File(dbFilePath);
        if (!dbFile.exists()) {
            throw new IllegalArgumentException(String.format("%s does not exist", dbFilePath));
        }

        // load the sqlite-JDBC driver using the current class loader
        Class.forName("org.sqlite.JDBC");

        Connection connection = null;
        try {
            // create a database connection
            connection = DriverManager.getConnection(String.format("jdbc:sqlite:%s", dbFilePath));
            Statement statement = connection.createStatement();
            statement.setQueryTimeout(30);  // set timeout to 30 sec.

            ResultSet rs = statement.executeQuery("select * from message");
            while (rs.next()) {
                // read the result set
                System.out.println(rs.getString("text"));
            }
        } catch (SQLException e) {
            // if the error message is "out of memory",
            // it probably means no database file is found
            System.err.println(e.getMessage());
        } finally {
            try {
                if (connection != null)
                    connection.close();
            } catch (SQLException e) {
                // connection close failed.
                System.err.println(e);
            }
        }
    }
}

我在OSX Mountain Lion上使用xerial sqlite-jdbc 3.7.2。

2 个答案:

答案 0 :(得分:3)

xven sqlite-jdbc的3.7.2版本是Maven中央存储库中的最新版本,似乎与OSX Mountain Lion不兼容。我不得不使用版本3.7.15-SNAPSHOT找到here

如果您使用的是maven,则可以使用以下sh文件:

#!/bin/sh
wget https://bitbucket.org/xerial/sqlite-jdbc/downloads/sqlite-jdbc-3.7.15-SNAPSHOT.jar
mvn install:install-file -Dfile=sqlite-jdbc-3.7.15-SNAPSHOT.jar -DgroupId=org.xerial -DartifactId=sqlite-jdbc -Dversion=3.7.15-SNAPSHOT -Dpackaging=jar
rm -f sqlite-jdbc-3.7.15-SNAPSHOT.jar

我也在Ubuntu 12.04 LTS上尝试过xerial sqlite-jdbc 3.7.2,它运行正常。

答案 1 :(得分:0)

我在OSX Maverick上遇到同样的问题。切换到3.7.15-M1,也可以在Maven的Central Repository上找到,解决了这个问题。