如何在android项目的资产文件夹中访问sqlite数据库?

时间:2012-08-03 18:14:11

标签: android sqlite

我需要帮助才能在android中使用我现有的sqlite数据库。

我将sqlite数据库放在“/ assets /(mydatabase)”中但无法使用它。

我正在使用以下代码。 有时它显示错误“无法打开数据库”,有时显示错误,如“找不到表”。 当我从ddms中提取数据库文件并使用sqlite浏览器打开它时,我的表就会丢失,这意味着我的表不再存在。

所以请帮助我了解如何在android中使用我现有的sqlite数据库进行读取和仪式操作。

private SQLiteDatabase MyDataBase;
private String path="/data/data/mypackagename/mydatabase";
try{
      MyDataBase=SQLiteDatabase.openDatabase(path, null,SQLiteDatabase.OPEN_READWRITE);
      Cursor myDbCursor;
      myDbCursor=MyDataBase.rawQuery("select user,password from login_master", null);
      String username=myDbCursor.getString(0);
      String password=myDbCursor.getString(01);
      Toast.makeText(getBaseContext(), username, 10).show();
      Toast.makeText(getBaseContext(), password, 10).show();
      MyDataBase.close();
  }
  catch(SQLiteException e){
      Toast.makeText(getBaseContext(), e.getMessage(), 10).show();
  }

2 个答案:

答案 0 :(得分:1)

不确定,但这可以帮到你

void checkDB() throws Exception {
    try {
        SQLiteDatabase dbe = SQLiteDatabase
                .openDatabase(
                        "/data/data/yourpackagename/databases/yourfilename.sqlite",
                        null, 0);
        Log.d("opendb", "EXIST");
        dbe.close();
    } catch (Exception e) {

        AssetManager am = getApplicationContext().getAssets();
        OutputStream os = new FileOutputStream(
                "/data/data/yourpackagename/databases/yourfilename.sqlite");
        byte[] b = new byte[100];

        int r;
        InputStream is = am.open("yourfilename.sqlite");
        while ((r = is.read(b)) != -1) {
            os.write(b, 0, r);
        }
        Log.i("DATABASE_HELPER", "Copying the database ");
        is.close();
        os.close();
    }

}

答案 1 :(得分:0)