Android SQLite onUpgrade = принудительное закрытие - PullRequest
1 голос
/ 23 ноября 2010

Вот ситуация. Я обновляю свою базу данных, добавляя один столбец. Обновление, кажется, идет хорошо. Я вижу добавленную новую колонку, но проблема заключается в том, что при обновлении моего приложения с более старой версии до новой версии с новой БД меня принудительно закрывают. Кажется, что принудительное закрытие происходит при доступе к новому столбцу. Если я делаю новую установку, однако, я не получаю принудительное закрытие и приложение работает, как ожидалось.

Мой up Upgrade выглядит так:

  @Override   public void onUpgrade(SQLiteDatabase notes_db, int oldVersion, int newVersion) {    if (oldVersion == 29) {
    notes_db.execSQL("ALTER TABLE Notes ADD COLUMN Priority text");
    notes_db.execSQL("ALTER TABLE Todo ADD COLUMN Priority text");
    notes_db.execSQL("ALTER TABLE Todo_keys ADD COLUMN Priority text");    } else {
    notes_db.execSQL("DROP TABLE IF EXISTS " + NOTES_TABLE);
    notes_db.execSQL("DROP TABLE IF EXISTS " + TODO_TABLE);
    notes_db.execSQL("DROP TABLE IF EXISTS " + TODO_KEYS_TABLE);
    onCreate(notes_db);    }      }

Любые идеи будут оценены.

Вот где я считаю, что это терпит неудачу ...

11-23 14:37:06.210: DEBUG/AndroidRuntime(1647): Shutting down VM
11-23 14:37:06.210: WARN/dalvikvm(1647): threadid=1: thread exiting with uncaught exception (group=0x4001d7e8)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647): FATAL EXCEPTION: main
11-23 14:37:06.210: ERROR/AndroidRuntime(1647): java.lang.NullPointerException
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at com.flufflydelusions.app.extensive_notes_donate.Notes$TaskSimpleCursorAdapter.getView(Notes.java:1065)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.AbsListView.obtainView(AbsListView.java:1315)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.ListView.measureHeightOfChildren(ListView.java:1198)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.ListView.onMeasure(ListView.java:1109)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.view.View.measure(View.java:8173)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1012)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.LinearLayout.measureVertical(LinearLayout.java:381)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.LinearLayout.onMeasure(LinearLayout.java:304)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.view.View.measure(View.java:8173)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.FrameLayout.onMeasure(FrameLayout.java:245)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.view.View.measure(View.java:8173)
11-23 14:37:06.210: ERROR/AndroidRuntime(1647):     at android.widget.LinearLayout.measureVertical(LinearLayout.java:526)

Строка 1065 - это оператор catch, а priority1 - новый столбец, который я добавил.

String priority1 = c.getString (c.getColumnIndex (databaseHelper.DB_COLUMN_PRIORITY));

        if (priority1.equals("Low")) {
            try {
                String low_pref = preferences.getString("low_priority_color", "Default");
                if (!low_pref.equals("Default")){
                    priority_text.setBackgroundColor(Integer.parseInt(low_pref, 16)+0xFF000000);
                    priority_text.setVisibility(View.VISIBLE);
                } else {
                    priority_text.setBackgroundColor(0xFFFFe640);
                    priority_text.setVisibility(View.VISIBLE);
                }} catch (Exception e) { 
                    errorText = e.getMessage();
                    themeError();
                }                   
            }   

1 Ответ

1 голос
/ 15 декабря 2010

Fixed. Новый столбец имел нулевое значение

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