0

データフォームテーブルをリストとしてフェッチし、それをサブリストに追加していますが、予期しない出力が得られます。必要な出力を取得できるように修正する方法がわかりません。コードを添付して、この問題の解決に役立ててください。

public List<List<String>> fetchData(){
    List<List<String>> main= new ArrayList<List<String>>();
    List<String> sub= new ArrayList<String>();
    String qry="SELECT * FROM "+myTable+"";
    SQLiteDatabase db= this.getReadableDatabase();
    Cursor cursor=db.rawQuery(qry, null);
    if (cursor.moveToFirst()) {
        do {
            System.out.println("-TblPOmaster-");
            sub.add(cursor.getString(0));               
            sub.add(cursor.getString(1));
            sub.add(cursor.getString(2));
            main.add(sub);
            System.out.println("Data:"+main);
        } while (cursor.moveToNext());      
    }
    cursor.close();
    db.close();
    return main;
}

Output what i'm Getting Now


Data:[[a1,a2,a3]]
    Data:[[a1,a2,a3,b1,b2,b3],[a1,a2,a3,b1,b2,b3]]
    Data:[[a1,a2,a3,b1,b2,b3,c1,c2,c3],[a1,a2,a3,b1,b2,b3,c1,c2,c3],[a1,a2,a3,b1,b2,b3,c1,c2,c3]]

Output what i need


Data:[[a1,a2,a3]]
    Data:[[a1,a2,a3],[b1,b2,b3]]
    Data:[[a1,a2,a3],[b1,b2,b3],[c1,c2,c3]]
4

1 に答える 1

0
  if (cursor.moveToFirst()) {
      do {
       List<String> sub= new ArrayList<String>();
        System.out.println("-TblPOmaster-");
        sub.add(cursor.getString(0));               
        sub.add(cursor.getString(1));
        sub.add(cursor.getString(2));
        main.add(sub);
        System.out.println("Data:"+main);
    } while (cursor.moveToNext());      
   }
   cursor.close();
   db.close();
return main;
}

カーソル内でサブリストを宣言してみてください。正常に機能します。

于 2012-10-31T07:47:53.870 に答える