web-dev-qa-db-ja.com

Android(sqliteデータベース)でデータベース値を文字列配列に取得する方法

私はデータベース名「CUED」(sqliteAndroid)を持っていますそれはテーブルを持っています[〜#〜] hello [〜#〜]列を含む[〜# 〜] name [〜#〜]その列からStringの値を取得できます。私のコードセクションをお見せしましょう

    myDB =hello.this.openOrCreateDatabase("CUED", MODE_PRIVATE, null); 
            Cursor crs = myDB.rawQuery("SELECT * FROM HELLO", null);


            while(crs.moveToNext())
            {
                String uname = crs.getString(crs.getColumnIndex("NAME"));
                System.out.println(uname);
 }

値を1つずつ出力します。必要なのは、データベースから列の値を取得して、それを文字列配列に格納できるようにすることです。

7
Ramz

あなたはすでに難しい部分をしました...配列のものはかなり単純です:

String[] array = new String[crs.getCount()];
int i = 0;
while(crs.moveToNext()){
    String uname = crs.getString(crs.getColumnIndex("NAME"));
    array[i] = uname;
    i++;
}

いずれにせよ、次のような場合は常にコレクションを使用することをお勧めします。

List<String> array = new ArrayList<String>();
while(crs.moveToNext()){
    String uname = crs.getString(crs.getColumnIndex("NAME"));
    array.add(uname);
}

配列を比較するために、次のようなことができます。

boolean same = true;
for(int i = 0; i < array.length; i++){
    if(!array[i].equals(ha[i])){
        same = false;
        break;
    }
}
// same will be false if the arrays do not have the same elements
26
Cristian

これは、arraylistにフィールド値が含まれていることを返す私のコードです。

public ArrayList<String> getAllPlayers() {

    SQLiteDatabase db = this.getReadableDatabase();
    Cursor cur = db.rawQuery("SELECT " + serailnumber + " as _id, " + title
            + " from " + table, new String[] {});
    ArrayList<String> array = new ArrayList<String>();
    while (cur.moveToNext()) {
        String uname = cur.getString(cur.getColumnIndex(title));
        array.add(uname);

    }
    return array;
}
0
Ribin Haridas
       String[] str= new String[crs.getCount()];
       crs.movetoFirst();           
     for(int i=0;i<str.length();i++)
        { 
           str[i] = crs.getString(crs.getColumnIndex("NAME"));
            System.out.println(uname);
      crs.movetoNext();
        }

楽しめ

0
Ramesh Solanki