Проблема с базой данных sqlite на платформе Android - PullRequest
1 голос
/ 19 марта 2010

Я занимаюсь разработкой приложения, которое использует sqlite db для хранения записей. Я разрабатываю это приложение на SDK 1.5 .., когда я тестирую приложение на устройстве 1.5, оно работает хорошо, но когда я пытаюсь запустить его на устройстве 1.6, я получаю сообщение принудительного закрытия со следующим выводом logcat:

03-19 09: 31: 35.206: ОШИБКА / AndroidRuntime (224): необработанный обработчик: выход из основного потока из-за необработанного исключения

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): java.lang.RuntimeException: невозможно запустить действие ComponentInfo {com.abc.android/com.abc.android.app}: android.database. sqlite.SQLiteException: невозможно открыть файл базы данных

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2454)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2470)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): на android.app.ActivityThread.access $ 2200 (ActivityThread.java:119)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.app.ActivityThread $ H.handleMessage (ActivityThread.java:1821)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): на android.os.Handler.dispatchMessage (Handler.java:99)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): на android.os.Looper.loop (Looper.java:123)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.app.ActivityThread.main (ActivityThread.java:4310)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в java.lang.reflect.Method.invokeNative (собственный метод)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в java.lang.reflect.Method.invoke (Method.java:521) 03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): на com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:860)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): на com.android.internal.os.ZygoteInit.main (ZygoteInit.java:618)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в dalvik.system.NativeStart.main (собственный метод)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): вызвано: android.database.sqlite.SQLiteException: невозможно открыть файл базы данных

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.database.sqlite.SQLiteDatabase.dbopen (собственный метод)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.database.sqlite.SQLiteDatabase. (SQLiteDatabase.java:1697)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.database.sqlite.SQLiteDatabase.openDatabase (SQLiteDatabase.java:738)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.database.sqlite.SQLiteDatabase.openOrCreateDatabase (SQLiteDatabase.java:760)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.database.sqlite.SQLiteDatabase.openOrCreateDatabase (SQLiteDatabase.java:753)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.app.ApplicationContext.openOrCreateDatabase (ApplicationContext.java:473)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): at android.content.ContextWrapper.openOrCreateDatabase (ContextWrapper.java:193)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.database.sqlite.SQLiteOpenHelper.getWritableDatabase (SQLiteOpenHelper.java:98)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в com.abc.android.DbAdapter.open (DbAdapter.java:101)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в com.abc.android.class1.onCreate (class1.java:105)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1047)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): в android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2417)

03-19 09: 31: 35.226: ОШИБКА / AndroidRuntime (224): ... еще 11

DBAdapter.java

public DbAdapter open() throws SQLException {

        Log.d("DbAdapter", "in DbAdapter open()");

        mDbHelper = new DatabaseHelper(mCtx);
        mDb = mDbHelper.getWritableDatabase();        // line 101
        return this;
    }

 DatabaseHelper(Context context) {
 super(context, DATABASE_NAME, null, DATABASE_VERSION); 
 }

 @Override
 public void onCreate(SQLiteDatabase db) {
    db.execSQL(DATABASE_QUERY);
 }              

class1.java

mDB = new DbAdapter(Class1.this);
mDB.open();             // line 105

Пожалуйста, помогите .. что мне делать ????

1 Ответ

1 голос
/ 17 мая 2010

Убедитесь, что DATABASE_NAME содержит значение, которое является просто именем файла и ничего более, без косой черты и т. Д.

Вот так: final String DATABASE_NAME = "mydata.db";

И если это выглядит хорошо, удалите приложение из меню приложений телефона и переустановите его.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...