Need help with SQLDroid?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

133 Stars 59 Forks MIT License 224 Commits 30 Opened issues


SQLite JDBC driver for Android & now also for non-Android platforms

Services available


Need anything else?

Contributors list

Build Status


SQLDroid is a JDBC driver for Android's sqlite database (android.database.sqlite.SQLiteDatabase) originally conceived by Kristian Lein-Mathisen. See

SQLDroid lets you access your app's database through JDBC. Android ships with the necessary interfaces needed to use JDBC drivers, but it does not officially ship with a driver for its built-in SQLite database engine. When porting code from other projects, you can conveniently replace the JDBC url to jdbc:sqlite to access an SQLite database on Android.

The SQLDroid JAR with the JDBC driver for Android is 33KB. We also offer a RubyGem "sqldroid" for use with Ruboto.


  • Project site:
  • Mailing list:
  • Wiki:
  • Old project site:


You can use SQLDroid in you maven project by declaring this dependency:


Or if you're using gradle:

compile 'org.sqldroid:sqldroid:1.0.3'

Binary distributions are available for download from the Maven Central Repository:


Here is a minimal example of an Android Activity implemented in Java with SQLDroid.

import java.sql.DriverManager;
import java.sql.Connection;
import java.sql.Driver;
import java.sql.SQLException;

public class MainActivity extends AppCompatActivity {

private Connection connection;

protected void onCreate(Bundle savedInstanceState) {
    try {
        DriverManager.registerDriver((Driver) Class.forName("org.sqldroid.SQLDroidDriver").newInstance());
    } catch (Exception e) {
        throw new RuntimeException("Failed to register SQLDroidDriver");
    String jdbcUrl = "jdbc:sqldroid:" + "/data/data/" + getPackageName() + "/my-database.db";
    try {
        this.connection = DriverManager.getConnection(jdbcUrl);
    } catch (SQLException e) {
        throw new RuntimeException(e);

public void onDestroy() {
    if (connection != null) {
        try {
        } catch (SQLException e) {
            throw new RuntimeException(e);


You can find an example of how to use SQLDroid with ActiveRecord on Ruboto here:

Debug output

You can set the SQLDroid log output level like this

org.sqldroid.Log.LEVEL = android.util.Log.VERBOSE;

You can turn on resultset dumps like this

org.sqldroid.SQLDroidResultSet.dump = true;


The SQLDroid JAR file is a straight collection of the compiled classes. If you have Ruby installed, you can generate the JAR using

rake jar

To make a gem for use with Ruboto run

rake gem

To release the gem to (requires permissions on run

rake release

Building with mvn

SQLDroid is a normal Maven project. If you have Android 21 installed (

sdkmanager --install platforms;android-21
), you can generate the JAR using

mvn install

To release the jar to Maven Central (requires permissions and a PGP key) first tag the release version

mvn -Prelease release:prepare

Then deploy the artifact to Maven Central

mvn -Prelease release:perform

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.