База данных не копируется из ресурса, хотя код выглядит нормально - PullRequest
0 голосов
/ 16 января 2020

Я столкнулся со странной ситуацией. Я использовал этот код в большинстве своих проектов и работал нормально, но я использовал его в новом проекте, и он не работает, я имею в виду, что моя база данных не копируется на телефон пользователя. Я просмотрел каждую строку и добавил журнал для каждого метода, но я не получаю никакого журнала. Приложение работает нормально, за исключением части базы данных.

DBAdapter:

public class DBAdapter extends SQLiteOpenHelper {

private static String DB_PATH;
private static String DB_NAME = "dictionary.db";
SQLiteDatabase db;
private Context c;



DBAdapter(Context context) {
    super(context, DB_NAME, null, 1);
    c = context;
    try {
        createDataBase();
    } catch (IOException e) {
        e.printStackTrace();
    }

}

public void createDataBase() throws IOException {
    boolean dbExist = checkDataBase();
    if (dbExist) {
        Toast.makeText(c,"done",Toast.LENGTH_LONG).show();
    } else {
        this.getReadableDatabase();
        try {
            copyDataBase();
        } catch (IOException e) {
            throw new Error("Can't copy database" + e);
        }
    }

}

private boolean checkDataBase() {
    DB_PATH = c.getApplicationInfo().dataDir + "/databases/";
    File dbFile = new File(DB_PATH + DB_NAME);
    return dbFile.exists();
}

private void copyDataBase() throws IOException {
    DB_PATH = c.getApplicationInfo().dataDir + "/databases/";
    InputStream inputStream = c.getAssets().open(DB_NAME);
    String outFileName = DB_PATH + DB_NAME;
    OutputStream outputStream = new FileOutputStream(outFileName);
    byte[] buffer = new byte[1024];
    int length;
    while ((length = inputStream.read(buffer))>0) {
        outputStream.write(buffer,0, length);
    }
    outputStream.flush();
    outputStream.close();
    inputStream.close();
}

public void openDataBase() {
    DB_PATH = c.getApplicationInfo().dataDir + "/databases/";
    String myPath = DB_PATH + DB_NAME;
    db = SQLiteDatabase.openDatabase(myPath, null,
            SQLiteDatabase.OPEN_READWRITE | SQLiteDatabase.NO_LOCALIZED_COLLATORS);

}

@Override
public synchronized void close() {
    if (db != null)
        db.close();
    super.close();
}
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...