无法通过Fragment - Android内部的上下文菜单从Custom ListView中删除DataBase行

时间:2013-10-31 02:28:23

标签: java android database sqlite

我已将数据添加到我的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);

1 个答案:

答案 0 :(得分:1)

代码将ID转换为字符串。

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

mDataBase.delete("orderTable", "_id = " + info.id, null);