Проблемы с заполнением ListView с помощью SQLite - PullRequest
0 голосов
/ 25 мая 2011

Я пытаюсь вставить свою собственную базу данных SQLite в просмотр списка андроида для просмотра, но у меня проблема, код выполняется, но генерирует «неожиданное завершение».

Я проверил свою DDMS, и эмулятор содержит мой файл SQLite в базе данных, который был скопирован из файла активов.

Я не уверен, что здесь пошло не так, может кто-нибудь подсказать мне, откуда мне начать смотреть? Или что-то не так с кодом, который я привел ниже? Где-нибудь, где я могу проверить потенциальные перегибы в коде?

Спасибо !!!

private void fillData() {

    Cursor drugsCursor = mDbHelper.fetchAllDrugs();
    startManagingCursor(drugsCursor);

        //Creating an array to specify the fields we want
    String[] from = new String[] {DrugsDbAdapter.KEY_ROWID};

        //and an array of the fields we want to bind in the view
    int[] to = new int[] {R.id.text1};

        //To Create the simple cursor adapter and set it to display
    SimpleCursorAdapter drugs = new SimpleCursorAdapter(this, R.layout.drug_row, drugsCursor, from, to);

    setListAdapter(drugs);

}

и DrugsDbAdapter.java, обрабатывающий курсор, находится здесь

public Cursor fetchAllDrugs() {     
    return mDb.query(DATABASE_TABLE, new String[] {KEY_ROWID, KEY_DRUG, KEY_CONTENT, KEY_INDICATION, KEY_DOSAGE, KEY_SPECIALPRECAUTION} , null, null, null, null, null);    
}

Вывод моего LogCat (часть вывода красного цвета - должен ли я публиковать весь журнал?):

05-25 18:12:22.338: WARN/dalvikvm(27763): threadid=1: thread exiting with uncaught exception (group=0x4001d800)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763): FATAL EXCEPTION: main
05-25 18:12:22.434: ERROR/AndroidRuntime(27763): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.paad.medboxsd/com.paad.medboxsd.medboxsd}: java.lang.NullPointerException
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.os.Looper.loop(Looper.java:123)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.app.ActivityThread.main(ActivityThread.java:4627)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at java.lang.reflect.Method.invokeNative(Native Method)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at java.lang.reflect.Method.invoke(Method.java:521)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at dalvik.system.NativeStart.main(Native Method)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763): Caused by: java.lang.NullPointerException
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at com.paad.medboxsd.medboxsd.fillData(medboxsd.java:67)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at com.paad.medboxsd.medboxsd.onCreate(medboxsd.java:56)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
05-25 18:12:22.434: ERROR/AndroidRuntime(27763):     ... 11 more
05-25 18:12:22.514: WARN/ActivityManager(59):   Force finishing activity com.paad.medboxsd/.medboxsd
05-25 18:12:23.034: WARN/ActivityManager(59): Activity pause timeout for HistoryRecord{450fc298 com.paad.medboxsd/.medboxsd}

1 Ответ

0 голосов
/ 25 мая 2011

Я подозреваю, что проблема в том, что вы не предоставляете столбец с именем _id для вашего курсора. См. Мой ответ на Android: столбец '_id' не существует проблема

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