我遇到了一个小问题,与我目前的项目。我正在做一个android应用程序,它需要连接到SQLite数据库来处理一些语句。我相信这些陈述等都很好,我唯一的问题是与数据库的连接不成功。Android SQLite数据库连接不成功
logcat的错误:
04-18 08:20:30.688: E/Database(304): sqlite3_open_v2("jdbc:sqlite:res/raw/randomdb.db", &handle, 1, NULL) failed
所以到目前为止我的代码,用于连接到数据库是这样的:
String url = "jdbc:sqlite:res/raw/randomdb.db";
SQLiteDatabase db;
db = SQLiteDatabase.openDatabase(url, null, SQLiteDatabase.OPEN_READONLY);
正如你可以看到,我试图存取权限位于数据库在我的项目/ res/raw文件夹中。有没有人看到错误?
!!!更新! * 我试图用SQLiteOpenHelper的方式,但仍然鼓励一个错误,我似乎无法解决。这是我的新代码: *
public class DatabaseAdapter extends SQLiteOpenHelper {
private static String dbPath= "data/data/com.YourPackageName/applicationDb/";
private static String dbName = "YourDBName";
private SQLiteDatabase applicationDatabase;
private final Context applicationContext;
private boolean checkDataBase(){
File dbFile = new File(dbPath + dbName);
return dbFile.exists();
}
public void openDataBase() throws SQLException{
String fullDbPath= dbPath + dbName;
applicationDatabase = SQLiteDatabase.openDatabase(fullDbPath,null,SQLiteDatabase.OPEN_READONLY);
}
@Override
public void onCreate(SQLiteDatabase db) {
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
我得到这个错误: 隐超构造SQLiteOpenHelper()是未定义默认构造函数。必须定义一个明确的构造函数 任何想法?会很好!
如果你想连接你与SQLite数据库Android应用