0

活動中のコードは次のとおりです。

//query
final dbhelper helper = new dbhelper(this);
Cursor c = helper.query();
boolean exist =false;
if(c != null && c.moveToFirst()){
Log.d("atestdbChar1no",String.valueOf(c.getCount()));   
int i=0;
while(c.isAfterLast()){
Log.d("atestdb1",String.valueOf(i++));
Log.d("atestdb2",String.valueOf(c.getInt(0)));
Log.d("atestdb3",c.getString(1));
Log.d("atestdb4",c.getString(2));
c.moveToNext(); 
}

//insert
      ContentValues values = new ContentValues();
      if(!finWords.equals("null")){
      if(finWords.length()>index){
      String selectWord = finWords.substring(index, index+1);
       values.put("character", finChar);
      values.put("word", selectWord);
      helper.insert(values);

SQLiteOpenHelper のコードは次のとおりです。

public void insert(ContentValues values) {
    SQLiteDatabase db = getWritableDatabase();
    db.insert(TBL_NAME, null, values);
    Log.d("test", "dbinsert");
    db.close();
}

public Cursor query() {
    SQLiteDatabase db = getWritableDatabase();
    Cursor c = db.query(TBL_NAME, null, null, null, null, null, null);
    Log.d("test", "dbquery");
    return c;
}

データベースにデータを挿入することはできますが、logcat でカーソル インデックスが範囲外であると言ってクエリを実行することはできません。たとえば、ID 1,2,4,7 で出力するだけで、アプリを強制的に閉じますが、既に 14 個のデータを挿入しています。私のコードが間違っていますか?

4

1 に答える 1

1

c.isAfterlast() を否定するのを忘れていました。null を返さない限り、null カーソルをチェックする必要はありません。

if(c.moveToFirst()){
Log.d("atestdbChar1no",String.valueOf(c.getCount()));   
int i=0;
while(!c.isAfterLast()){
Log.d("atestdb1",String.valueOf(i++));
Log.d("atestdb2",String.valueOf(c.getInt(0)));
Log.d("atestdb3",c.getString(1));
Log.d("atestdb4",c.getString(2));
c.moveToNext(); 
}
于 2013-04-15T05:24:03.320 に答える