不在Android中使用ArrayList显示ListView中的记录

时间:2013-07-24 08:38:26

标签: android sqlite listview

我想用数据库中保存的所有数据填充Listview,但是我无法检索所有数据而只获得第一条记录和记录本身的数量。

MainActivity.java

    //Populating the ListView
    ArrayList<HashMap<String, String>> mylistData = new ArrayList<HashMap<String, String>>();

    int[] columnIds = new int[] {R.id.tv_Lastname, R.id.tv_Firstname, R.id.tv_MI, R.id.tv_Birthdate, R.id.tv_HomeNo,
            R.id.tv_Mobile, R.id.tv_email, R.id.tv_Brgy};

    ArrayList<String> arrayPatientData = db.arrayListPatientData();
    Cursor cursor = db.getPatientData();

    for(int i=0; i<cursor.getCount(); i++) {
        HashMap<String,String> map = new HashMap<String, String>();

        for(int j=0; j<arrayPatientData.size(); j++) {
            Cursor cursorPatientData = db.getPatientData(j);
            //Cursor cursorCityData = db.getCityData();
            //Cursor cursorProvinceData = db.getProvinceData();

            firstname = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_FNAME));
            lastname = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_LNAME));
            middlename = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_MNAME));
            bday = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_BIRTHDAY));
            homeNo = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_HOME_NO));
            mobileNo = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_MOB_NO));
            email = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_EMAIL));
            brgy = cursorPatientData.getString(cursorPatientData.getColumnIndex(Constants.PATIENT_BRGY));
            //city = cursorCityData.getString(cursorCityData.getColumnIndex(Constants.CITY_ID));
            //province = cursorProvinceData.getString(cursorProvinceData.getColumnIndex(Constants.PROVINCE_ID));

            map.put(FIRSTNAME, firstname);
            map.put(LASTNAME, lastname);
            map.put(MIDDLENAME, middlename);
            map.put(BDAY, bday);
            map.put(HOMENO, homeNo);
            map.put(MOBILENO, mobileNo);
            map.put(EMAIL, email); 
            map.put(BRGY, brgy);
            //map.put(CITY, city);
            //map.put(PROVINCE, province);
        }

        mylistData.add(map);
    }
    SimpleAdapter arrayAdapter = new SimpleAdapter(getApplicationContext(), mylistData, R.layout.attribute_patient, 
            new String[] {FIRSTNAME, LASTNAME, MIDDLENAME, BDAY, HOMENO, MOBILENO, EMAIL, BRGY} , columnIds);
    lv_Patient.setAdapter(arrayAdapter);

DatabaseHandler.java

public Cursor getPatientData(int _id)
    {
        SQLiteDatabase db = this.getReadableDatabase();
        Cursor c = db.query(Constants.TABLE_PATIENT, new String[] { 
                Constants.PATIENT_ID, Constants.PATIENT_FNAME, Constants.PATIENT_LNAME,
                Constants.PATIENT_MNAME, Constants.PATIENT_BIRTHDAY, Constants.PATIENT_HOME_NO, 
                Constants.PATIENT_MOB_NO, Constants.PATIENT_EMAIL, Constants.PATIENT_BRGY,
                Constants.F_PATIENT_CITY_ID, Constants.F_PATIENT_PROVINCE_ID}, Constants.PATIENT_ID + "=?", 
                new String[] {String.valueOf(_id)}, null, null, null);
        if (c != null) {
            c.moveToFirst();
        }
        db.close();
        return c;       
    }

    //Get User Data
    public Cursor getPatientData()
    {
        SQLiteDatabase db = this.getReadableDatabase();
        Cursor c = db.query(Constants.TABLE_PATIENT, new String[] { 
                Constants.PATIENT_ID, Constants.PATIENT_FNAME, Constants.PATIENT_LNAME,
                Constants.PATIENT_MNAME, Constants.PATIENT_BIRTHDAY, Constants.PATIENT_HOME_NO, 
                Constants.PATIENT_MOB_NO, Constants.PATIENT_EMAIL, Constants.PATIENT_BRGY,
                Constants.F_PATIENT_CITY_ID, Constants.F_PATIENT_PROVINCE_ID}, null, null, null, null, null);
        if (c != null) {
            c.moveToFirst();
        }
        db.close();
        return c;       
    }

logcat的:

07-24 18:31:29.585: E/AndroidRuntime(14671): FATAL EXCEPTION: main
07-24 18:31:29.585: E/AndroidRuntime(14671): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.palsproject/com.example.palsproject.S_5th_Search_Patient}: android.database.CursorIndexOutOfBoundsException: Index 0 requested, with a size of 0
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1970)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1995)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.ActivityThread.access$600(ActivityThread.java:128)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1161)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.os.Handler.dispatchMessage(Handler.java:99)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at     android.os.Looper.loop(Looper.java:137)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.ActivityThread.main(ActivityThread.java:4514)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at java.lang.reflect.Method.invokeNative(Native Method)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at java.lang.reflect.Method.invoke(Method.java:511)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at dalvik.system.NativeStart.main(Native Method)
07-24 18:31:29.585: E/AndroidRuntime(14671): Caused by: android.database.CursorIndexOutOfBoundsException: Index 0 requested, with a size of 0
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.database.AbstractCursor.checkPosition(AbstractCursor.java:400)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.database.AbstractWindowedCursor.checkPosition(AbstractWindowedCursor.java:136)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.database.AbstractWindowedCursor.getString(AbstractWindowedCursor.java:50)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at com.example.palsproject.S_5th_Search_Patient.onCreate(S_5th_Search_Patient.java:66)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.Activity.performCreate(Activity.java:4465)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1053)
07-24 18:31:29.585: E/AndroidRuntime(14671):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1934)
07-24 18:31:29.585: E/AndroidRuntime(14671):    ... 11 more

0 个答案:

没有答案