0

我已将数据添加到我的 SQLite 数据库中,它显示在 listView 中。但我想用上下文菜单删除它。上下文菜单正在显示,但数据没有被删除。

这是我的代码示例:

@Override
public void onCreateContextMenu(ContextMenu menu, View v,ContextMenu.ContextMenuInfo menuInfo) {
    super.onCreateContextMenu(menu, v, menuInfo);
    MenuInflater inflater = getActivity().getMenuInflater();
    inflater.inflate(R.menu.context_menu, menu);
}

@Override
public boolean onContextItemSelected(MenuItem item) {

    AdapterView.AdapterContextMenuInfo info = (AdapterView.AdapterContextMenuInfo)item.getMenuInfo();
    mDataBase = dbHelper.getWritableDatabase();

    switch(item.getItemId()) {
        case R.id.delete:

            mDataBase.delete("orderTable", "_id" + " =? ", new String[] {String.valueOf(info.id)});

            dbAdaper.setArrayMyData(selectAll());
            dbAdaper.notifyDataSetChanged();
            mDataBase.close();

    }
    return super.onContextItemSelected(item);
}

我发现 info.id 的值为 0。

 dbAdaper = new DBBasketAdapter(getActivity(), selectAll());
    listView.setAdapter(dbAdaper);
    registerForContextMenu(listView);
4

1 回答 1

1

该代码将 ID 转换为字符串。

对于整数,不需要使用 SQL 参数;只需直接使用该值:

mDataBase.delete("orderTable", "_id = " + info.id, null);
于 2013-10-31T09:41:05.580 回答