2

我需要在 Android 应用程序上使用数据库,因为在使用时用户将无法访问互联网。为此,我想使用 SQL Lite 通过 JDBC 连接到数据库。经过一番研究,我发现 Android API 不支持它,但是有一个项目可以做到这一点:SQLDroid

java.sql.SQLException: No suitable driver 我下载了罐子并按照主要教程进行操作,但是当我想创建与 DriverManager 的连接时,我不断收到 sql 异常。

String url = "jdbc:sqldroid:" + "/data/data/com.mypackage.droid" + "/main.sqlite";
Connection con = DriverManager.getConnection(url);

我究竟做错了什么?顺便说一句,我的活动名为“AndroidActivity”,包名为 com.mypackage.droid。

编辑:完整代码:

public class AndroidActivity extends Activity {


    String url = "jdbc:sqldroid:" + "/data/data/com.mypackage.droid" + "/main.sqlite";
    static Connection con;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        try {
            Class.forName("SQLite.JDBCDriver");
            con = DriverManager.getConnection(url);
        } catch (java.sql.SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }


    }
4

2 回答 2

2

使用 sqldroid-1.0.0RC1.jar 我正在使用

Class.forName("org.sqldroid.SqldroidDriver");
con = DriverManager.getConnection(url);

有时驱动程序可以通过驱动程序管理器加载,有时它会失败。

作为一个工作人员,我直接使用 SQLDroidDriver,这一直有效。

con = new org.sqldroid.SQLDroidDriver().connect(url , new Properties());
于 2013-02-19T15:02:09.190 回答
2

您是否声明:

Class.forName("SQLite.JDBCDriver");

在声明连接之前?

编辑:

抱歉,我想,您想使用本机 Android JDBC 驱动程序。在这种情况下,这将是我的方法。

但是由于您使用的是自带驱动程序的 SQLDroid 库,因此您必须先注册驱动程序。喜欢:

Class.forName("org.sqldroid.SqldroidDriver").newInstance();
于 2011-10-27T14:05:40.380 回答