在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;}这就是问题所在,而不是“=”它是“-”)