アプリケーションを作成していますが、Cursor
に問題があります。この関数で値を取得しようとすると、SQLiteDatabase
を返すCursor
があります。
public Cursor fetchOption(long rowId) throws SQLException {
Cursor mCursor = mDb.query(true, DATABASE_TABLE, new String[] {KEY_ROWID,
KEY_TITLE, KEY_BODY}, KEY_ROWID + "=" + rowId, null,
null, null, null, null);
if (mCursor != null) {
mCursor.moveToFirst();
}
return mCursor;
}
Cursor
のフィールドの値を取得する方法がわかりません。私がそうするなら:
String a = mOptionDb.fetchOption(0).getColumnName(0).toString();
String b = mOptionDb.fetchOption(0).getColumnName(1).toString();
String c = mOptionDb.fetchOption(0).getColumnName(2).toString();
列の名前(_id, title, body
)しかし値ではありません。これを達成する方法に関する提案はありますか?
Nullのチェックを忘れることができると思います。
代わりに、データがあるかどうかを確認し、カーソルを使用して列にアクセスします。
Cursor cursor = fetchOption(0);
if (cursor.moveToFirst()) // data?
System.out.println(cursor.getString(cursor.getColumnIndex("title"));
cursor.close(); // that's important too, otherwise you're gonna leak cursors
Androidチュートリアル。メモ帳のチュートリアルは法案に合うようです: http://developer.Android.com/guide/tutorials/notepad/index .html
Cursor
のget*
メソッドを使用して、結果から値を取得できます。
long id = cursor.getLong(cursor.getColumnIndex("_id"));
long title = cursor.getString(cursor.getColumnIndex("title"));
...
明らかに、ハードコードされた文字列でgetColumnIndex
を呼び出す代わりに、定数(ContentProvidersによって提供されることが多い)を使用することをお勧めします。
このメカニズムを使用できます。
Cursor record=db.test(finalDate);
if(record.getCount()!=0){
if(record.moveToFirst()){
do{
Imgid1=record.getString(record.getColumnIndex(Database.PHOTO));
}while(record.moveToNext());
}
record.close();
}