我已经将数据添加到我的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);
最佳答案
该代码将ID转换为字符串。
对于整数,不需要使用SQL参数。只需直接使用该值:
mDataBase.delete("orderTable", "_id = " + info.id, null);