android.database.sqlite.SQLiteCantOpenDatabaseException: неизвестная ошибка (код 14): не удалось открыть проблему с базой данных
27429 просмотра
1 ответ
Я пытаюсь исправить ошибку, которая не позволяет мне открыть базу данных. Возможно, после всех слияний что-то пошло не так, но я не могу найти это. Вот мой Log Cat
отчет.
E/SQLiteLog(894): (14) cannot open file at line 30191 of [00bb9c9ce4]
E/SQLiteLog(894): (14) os_unix.c:30191: (2) open(/data/data/com.packagename/databases/MainDB) -
Failed to open database '/data/data/com.packagename/databases/MainDB'.
android.database.sqlite.SQLiteCantOpenDatabaseException: unknown error (code 14): Could not open database
at android.database.sqlite.SQLiteConnection.nativeOpen(Native Method)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:209)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:193)
at android.database.sqlite.SQLiteConnectionPool.openConnectionLocked(SQLiteConnectionPool.java:463)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:185)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:177)
at android.database.sqlite.SQLiteDatabase.openInner(SQLiteDatabase.java:804)
at android.database.sqlite.SQLiteDatabase.open(SQLiteDatabase.java:789)
at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:694)
at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:669)
at com.packagename.database.DBAdapter$DatabaseHelper.checkDataBase(DBAdapter.java:757)
at com.packagename.database.DBAdapter$DatabaseHelper.createDataBase(DBAdapter.java:734)
at com.packagename.database.DBAdapter.resetAllData(DBAdapter.java:490)
at com.packagename.OptionActivity$4.onClick(OptionActivity.java:157)
at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:166)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
И вот фрагменты кода, который виден (или связан) назад в журнал.
Опция Активность
public void onClick_ResetAll(final View v) {
....
....
@Override
public void onClick(DialogInterface dialog, int which) {
TrackUtils.sendClickTrack(OptionActivity.this, "ui_action", "button_press", "Resetall_yes");
final DBAdapter dba = new DBAdapter(v.getContext());
dba.open();
dba.resetAllData(v.getContext());
dba.close();
}
....
....
}
DBAdapter Class
private DatabaseHelper mDbHelper;
private static SQLiteDatabase mDb;
@SuppressLint("SdCardPath")
private static String DB_PATH;
private static final String DATABASE_NAME = "MainDB";
private static final int DATABASE_VERSION = 3;
private final Context adapterContext;
public DBAdapter(Context context) {
this.adapterContext = context;
DB_PATH = adapterContext.getFilesDir().getAbsolutePath().replace("files", "databases")
+ File.separator;
}
public DBAdapter open() throws SQLException {
mDbHelper = new DatabaseHelper(adapterContext);
try {
mDbHelper.createDataBase();
} catch (IOException ioe) {
throw new Error("Unable to create database");
}
try {
mDbHelper.openDataBase();
} catch (SQLException sqle) {
throw sqle;
}
return this;
}
public void resetAllData(Context context) {
context.deleteDatabase("MainDB");
mDbHelper = new DatabaseHelper(adapterContext);
try {
mDbHelper.createDataBase();
} catch (IOException ioe) {
throw new Error("Unable to create database");
}
try {
mDbHelper.openDataBase();
} catch (SQLException sqle) {
throw sqle;
}
}
DatabaseHelper (расширяет SQLiteOpenHelper)
DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
helperContext = context;
}
public void createDataBase() throws IOException {
boolean dbExist = checkDataBase();
if (dbExist) {
} else {
this.getReadableDatabase();
try {
copyDataBase();
} catch (IOException e) {
throw new Error("Error copying database");
}
}
}
private boolean checkDataBase() {
SQLiteDatabase checkDB = null;
try {
String myPath = DB_PATH + DATABASE_NAME;
checkDB = SQLiteDatabase.openDatabase(myPath, null,
SQLiteDatabase.OPEN_READONLY); // This is where the error apparently occurs
} catch (SQLiteException e) {
}
if (checkDB != null) {
checkDB.close();
}
return checkDB != null ? true : false;
}
Я искал решения на этом сайте, но безрезультатно.
Автор: Hayden Источник Размещён: 12.11.2019 09:50Ответы (1)
16 плюса
Решение
Вы используете SQLiteDatabase.openDatabase
путь к файлу, который может не существовать. Добавьте ниже 2 строки перед SQLiteDatabase.openDatabase
вызовом
File file = new File(myPath);
if (file.exists() && !file.isDirectory())
Автор: ashoke
Размещён: 01.10.2014 06:32
Вопросы из категории :
- android Насколько хорошо отражает эмулятор Android Phone?
- android Как сохранить состояние активности Android с помощью сохранения состояния экземпляра?
- android Android: доступ к дочерним представлениям из ListView
- android Как вызвать SOAP веб-сервис на Android
- android Как вы форматируете дату и время в Android?
- android Android: Получение имени файла с камеры?
- android Перезапуск активности при ротации Android
- android Проблема с нехваткой памяти при загрузке изображения в растровый объект
- android Отправьте приложение с базой данных
- android Как удалить контакт программно в Android
- sqlite Как вывести данные некоторых таблиц SQLite3?
- sqlite Как я могу объединить многие базы данных SQLite?
- sqlite Как узнать, уникален ли индекс SQLite? (С SQL)
- sqlite Легкая альтернатива Hibernate?
- sqlite Почему я не могу установить гем SQLite?
- sqlite Как я могу ссылаться на столбцы по их именам в python, вызывающем SQLite?
- sqlite Где можно найти исходные архивы старых версий SQLite?
- sqlite Как получить список имен столбцов
- sqlite Set start value for AUTOINCREMENT in SQLite
- sqlite Как сделать ОБНОВЛЕНИЕ при объединении таблиц на SQLite?