在android中从数据库中删除项目

在android中从数据库中删除项目,android,database,Android,Database,我有个小问题。我试图从存储在数据库中的列表中删除一项。当我选择“删除列表”时,所有其他项目都会被删除,但我选择的项目不会被删除。我不明白我的错误在哪里。请帮忙 这是我的密码: public class IncercListe extends Activity { TextView txt; String value; Button btn; private ListView lv1; private AlertDialog alertDialog;

我有个小问题。我试图从存储在数据库中的列表中删除一项。当我选择“删除列表”时,所有其他项目都会被删除,但我选择的项目不会被删除。我不明白我的错误在哪里。请帮忙

这是我的密码:

public class IncercListe extends Activity {

    TextView txt;
    String value;
    Button btn;
    private ListView lv1;
    private AlertDialog alertDialog;
    private ArrayAdapter<String> m_adapter;
    Bundle bundle ;
    String item;
    private Cursor cursor;
    private ListDbAdapter db;

    private static final int MENU_CREATE = Menu.FIRST;
    private static final int MENU_RENAME=Menu.FIRST+1;
    private static final int MENU_EDIT = Menu.FIRST + 2;
    private static final int MENU_SEND=Menu.FIRST+3;
    private static final int MENU_DELETE=Menu.FIRST+4;

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.list1);

        lv1=(ListView)findViewById(R.id.list);

        db=new ListDbAdapter(this);
        db.open();
        fillData();
        registerForContextMenu(lv1);

        lv1.setOnItemClickListener(new OnItemClickListener()
         {

           public void onItemClick(AdapterView<?> parent,View v,int position, long id)
           {
               Intent j= new Intent(IncercListe.this, List.class);
               startActivity(j);
           }
         });

     public void onCreateContextMenu(ContextMenu menu, View v,  ContextMenuInfo menuInfo) {  
             menu.setHeaderTitle("Choose ");  
             menu.add(0, MENU_RENAME, 0, "Rename List");  
             menu.add(0, MENU_EDIT, 0,  "Edit List");
             menu.add(0, MENU_SEND, 0,  "Send List");
             menu.add(0, MENU_DELETE, 0, "Delete List");
        }    
    @Override
    public boolean onContextItemSelected(MenuItem mitem) {     
        switch (mitem.getItemId()) {  
            case MENU_RENAME:  
                rename();
                return true;  

            case MENU_EDIT: 
                   Intent j= new Intent(IncercListe.this, List.class);
                   startActivity(j);                
                return true; 

            case MENU_SEND:
                return true;

            case MENU_DELETE:
                AdapterContextMenuInfo info=(AdapterContextMenuInfo)mitem.getMenuInfo();
                db.delete(info.id);
                fillData();
                    return true;
            default:    
                return super.onContextItemSelected(mitem);  
        }
    }   
    public boolean onCreateOptionsMenu(Menu menu) {    
        menu.add(0, MENU_CREATE, 0, "New List");//.setIcon(R.drawable.quit); 
        return true;
    }
    /* Handles item selections */
   public boolean onOptionsItemSelected (MenuItem item) {    
        switch (item.getItemId()) {    
            case MENU_CREATE:        
                createlist();
                return true;  
        }
        return false;
    }

    public void createlist() {    
        alertDialog = new AlertDialog.Builder(this).create();
        alertDialog.setTitle("New List");
        alertDialog.setMessage("Enter name of new shopping list :");

        final EditText edt=new EditText(this);
        alertDialog.setView(edt);
        alertDialog.setButton("OK", new DialogInterface.OnClickListener() {
             public void onClick(DialogInterface dialog, int which) {
                      item =edt.getText().toString();
                      if (!item.equals("")) db.create(item);
                      fillData();
                       return;
             }
         });
        alertDialog.setButton2("Cancel", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int which) {
                dialog.cancel();
                   return;
            }
        }); 
        alertDialog.show();

    }
    public void rename() {      
    }
    public void sendlist(){
    }    
    protected void onActivityResult(int requestCode, int resultCode, Intent intent){
        super.onActivityResult(requestCode, resultCode, intent);
        fillData();
    }
    private void fillData(){
        cursor=db.fetchAll();
        startManagingCursor(cursor);

        ListAdapter adapter=new SimpleCursorAdapter(this,R.layout.textview,cursor,
                new String[] {ListDbAdapter.KEY_TITLE},new int[] {R.id.txt1});
        lv1.setAdapter(adapter);
    }

}
公共类IncercListe扩展活动{
文本视图;
字符串值;
按钮btn;
私有ListView lv1;
私人AlertDialog AlertDialog;
专用阵列适配器m_适配器;
束;
字符串项;
私有游标;
私有listdadapter数据库;
私有静态最终整数菜单_CREATE=MENU.FIRST;
私有静态final int MENU_RENAME=MENU.FIRST+1;
私有静态最终整数菜单_EDIT=MENU.FIRST+2;
私有静态最终整数菜单\发送=菜单。第一个+3;
私有静态最终整数菜单_DELETE=MENU.FIRST+4;
创建时的公共void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.list1);
lv1=(ListView)findViewById(R.id.list);
db=新的ListDbAdapter(此);
db.open();
fillData();
registerForContextMenu(lv1);
lv1.setOnItemClickListener(新的OnItemClickListener()
{
public void onItemClick(AdapterView父视图、视图v、整型位置、长id)
{
意图j=新意图(IncercListe.this,List.class);
星触觉(j);
}
});
public void onCreateContextMenu(ContextMenu菜单,视图v,ContextMenuInfo菜单信息){
菜单。设置标题(“选择”);
添加(0,菜单\重命名,0,“重命名列表”);
添加(0,菜单编辑,0,“编辑列表”);
添加(0,menu_SEND,0,“发送列表”);
菜单添加(0,菜单删除,0,“删除列表”);
}    
@凌驾
公共布尔值onContextItemSelected(MenuItem mitem){
开关(mitem.getItemId()){
案例菜单\u重命名:
重命名();
返回true;
案例菜单\u编辑:
意图j=新意图(IncercListe.this,List.class);
星触觉(j);
返回true;
案例菜单\u发送:
返回true;
案例菜单\u删除:
AdapterContextMenuInfo信息=(AdapterContextMenuInfo)mitem.getMenuInfo();
db.delete(info.id);
fillData();
返回true;
违约:
返回super.onContextItemSelected(mitem);
}
}   
公共布尔onCreateOptions菜单(菜单菜单){
menu.add(0,menu_CREATE,0,“新建列表”);/.setIcon(R.drawable.quit);
返回true;
}
/*处理项目选择*/
公共布尔值onOptionsItemSelected(MenuItem项){
开关(item.getItemId()){
案例菜单\u创建:
createlist();
返回true;
}
返回false;
}
public void createlist(){
alertDialog=新建alertDialog.Builder(this.create();
alertDialog.setTitle(“新列表”);
setMessage(“输入新购物清单的名称:”);
最终编辑文本edt=新编辑文本(本);
alertDialog.setView(edt);
alertDialog.setButton(“确定”,新的DialogInterface.OnClickListener(){
public void onClick(DialogInterface dialog,int which){
item=edt.getText().toString();
如果(!item.equals(“”)db.create(item);
fillData();
回来
}
});
alertDialog.setButton2(“取消”,新建DialogInterface.OnClickListener()){
public void onClick(DialogInterface dialog,int which){
dialog.cancel();
回来
}
}); 
alertDialog.show();
}
public void rename(){
}
公共无效发送列表(){
}    
ActivityResult上受保护的void(int-requestCode、int-resultCode、Intent-Intent){
super.onActivityResult(请求代码、结果代码、意图);
fillData();
}
私有void fillData(){
cursor=db.fetchAll();
开始管理游标(游标);
ListAdapter=new SimpleCursorAdapter(这个,R.layout.textview,游标,
新字符串[]{listdadapter.KEY_TITLE},新int[]{R.id.txt1});
lv1.设置适配器(适配器);
}
}

我不完全确定,但您可能想调用call db.delete(info.position)而不是db.delete(info.id)。

现在我尝试了db.delete(info.position),但一切都被删除了。我不明白为什么。:(我发现了我的错误。这是在我的函数delete from listdadapter中。它看起来像这样:public boolean delete(long rowId){return mDb.delete(DATABASE_TABLE,KEY_ROWID+“=”+ROWID,null)>0;}这就是问题所在,而不是“=”它是“-”)