1

現在、アプリケーションで非常に厄介な問題が発生しています。目標は、ユーザーがクリックしているボタンに応じて、データベースからリストビューのさまざまな情報を読み取ることです。残念ながら、私のアプリケーションは常にクラッシュし、stackoverflow に関する同様の質問の中で有効な解決策を見つけることができませんでした (データベースのバージョンの変更、カーソルに関するいくつかの行の追加などを試みました)。

私のコードの関連部分は次のとおりです。

A. DatabaseAdapter クラス:

public class DatabaseAdapter {

public static final String DATABASE_TABLE = "Restaurants";

public static final String COL_CAT1 = "cat1";
public static final String KEY_ROWID = "_id";
public static final String COL_CAT2 = "cat2";
public static final String COL_NAME = "name";
public static final String COL_COMMENTS = "comments";

private Context myContext;
private SQLiteDatabase myDatabase;
private DatabaseHelper dbHelper;
private Cursor c;

// Constructor
public DatabaseAdapter(Context context) {
    this.myContext = context;

}

public DatabaseAdapter open() throws SQLException {
    dbHelper = new DatabaseHelper(myContext);
    // TODO: or maybe?
    // database = dbHelper.getWritableDatabase();
    try {
        dbHelper.createDatabase();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    myDatabase = dbHelper.getReadableDatabase();
    return this;
}

public void close() {
    if (c != null) {   
        c.close();
    }
    try {
        dbHelper.close();
        myDatabase.close();
    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}


public Cursor findNameInTable(int myVariable) {
    c = myDatabase
            .query(DATABASE_TABLE, new String[] { COL_NAME , COL_COMMENTS }, 
                    COL_CAT1+"=?",
                    new String[] { Integer.toString(myVariable) }, null,
                    null, null);
    return c;
}

}

B. ResultListViewActivity (結果は、このアクティビティを介して ListView に表示されるはずです):

public class ResultListViewActivity extends Activity {

private SimpleCursorAdapter cursorAdapter;
private DatabaseAdapter dbHelper;
ListView listview;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_result_list_view);

    dbHelper = new DatabaseAdapter(this); // open() method is in DatabaseAdapter

    dbHelper.open();


    displayListView();
}

private void displayListView() {

    Bundle bundle = getIntent().getExtras();
    int myVariable = bundle.getInt("myVariable");

    Cursor c = dbHelper.findNameInTable(myVariable);
    // the desired columns to be bound
    String[] columns = new String[] { DatabaseAdapter.COL_NAME,
            DatabaseAdapter.COL_COMMENTS, };
    // the XML defined views which the data will be bound to
    int[] to = new int[] { R.id.name, R.id.comments, };
    // create the adapter using the cursor pointing to the desired data
    // as well as the layout information
    cursorAdapter = new SimpleCursorAdapter(this, R.layout.poi_info, c,
            columns, to, 0);

    ListView listView = (ListView) findViewById(R.id.listview);
    // Assign adapter to ListView
    listView.setAdapter(cursorAdapter);
}

私のデータベースの写真: ご覧のとおり、実際には _id 列があります: ここに画像の説明を入力

最後に、次の場合の logcat の写真:
ここに画像の説明を入力

私のコードの他の部分を見たい場合は、お知らせください。どんな種類の助けにも感謝します!

4

1 に答える 1

1

すべての ListView には、その選択クエリに _id 列が必要です。リスト クエリに _id 列を含める必要があります。

クエリを次のように変更します。

c = myDatabase
        .query(DATABASE_TABLE, new String[] { KEY_ROWID,COL_NAME , COL_COMMENTS }, 
                COL_CAT1+"=?",
                new String[] { Integer.toString(myVariable) }, null,
                null, null);
于 2013-03-05T06:39:41.947 に答える