0

なぜこれが機能しないのか誰にも分かりますか。テーブルに単純な行を追加して、正しく追加されたことを確認しようとしています。テーブルをクエリしようとすると、プログラムがクラッシュします。これをずっと見つめていると頭が痛い。

addNewGame(1);

Cursor cursor2 = db.query(myDBOpenHelper.GAMES_TABLE, new String [] {"MAX("+GAME_COLUMN+") AS GC"}, null, null, null, null, null);
System.err.println("made it this far");     
String temp = cursor2.getString(cursor.getColumnIndex("GC")); //crash!!!
System.err.println("didn't get here);


private static void addNewGame(int g) {
        ContentValues newValues = new ContentValues();
    SQLiteDatabase db = DBOpenHelper.getWritableDatabase(); 
    newValues.put(GAME_COLUMN, g);
    newValues.put(CIV_COLUMN, "");
    db.insert(myDBOpenHelper.GAMES_TABLE, null, newValues);
}

キャッチされない例外でスレッドが終了する

また、テーブルが作成された場所のコードは次のとおりです。

private static final String GAMES_CREATE =  "create table " +
            GAMES_TABLE + " (" + KEY_ID +
            " integer primary key autoincrement, " +
            GAME_COLUMN + " text not null, " +
            CIV_COLUMN + " text);";
db.execSQL(GAMES_CREATE);
4

1 に答える 1

1

カーソルがnullになることを確認してください。このコードを試してみてください。

if(cursor2.getcount>0)
{
cursor2.moveTofirst();
String temp = cursor2.getString(cursor.getColumnIndex("GC"));
}

これを試してみてください。

于 2012-12-07T06:34:16.297 に答える