0

我有一个列表视图,其中将显示我的 SQL 查询。现在我添加了一个OnItemClickListener在点击时删除条目:

lv.setOnItemClickListener(new OnItemClickListener()
{
public void onItemClick(AdapterView<?> arg0,View arg1,int arg2, long arg3){
    ListView lv = (ListView) findViewById(R.id.listView1);      
    final String Name = lv.getAdapter().getItem(arg2).toString();
    final String ID = String.valueOf(arg3);

    CharSequence dbeintrag = getString(R.string.dbeintrag);
    CharSequence yes = getString(R.string.yes);
    CharSequence no = getString(R.string.no);
    Builder alertDialog = new AlertDialog.Builder(EP.this);
    alertDialog.setTitle(Name);
    alertDialog.setMessage(dbeintrag);
    alertDialog.setCancelable(true);
    alertDialog.setPositiveButton(yes, new DialogInterface.OnClickListener() {
        public void onClick(DialogInterface dialog, int which) {
            deleteentry(Name,ID);
            fillSQLData(); // refresh
        } }); 

    alertDialog.setNegativeButton(no, new DialogInterface.OnClickListener() {
        public void onClick(DialogInterface dialog, int which) {

        } }); 
    alertDialog.show();
}
});  

}

 public void deleteentry(String Name,long ID) // Lösche Eintrag
    {
        DataBaseHelper myDbHelper = new DataBaseHelper(null);
        myDbHelper = new DataBaseHelper(this);

        ID = ID+1; // Anpassen zur DB

        SQLiteDatabase database = myDbHelper.getWritableDatabase();
        database.execSQL("DELETE FROM Heute WHERE Name='"+Name+"' and _id='"+ID+"'");
        mPLAdapter.notifyDataSetChanged();
    }

现在我的问题是我在数据库中的 ID 不是我从onItemClick函数中获得的 ID。例如,我将添加 3 个条目,全部删除,添加 3 个新条目。对于函数,第一个条目是 0,在 SQL 数据库中它的第一个条目是 4...

解决此问题的最佳解决方案是什么?

比你好多了!

4

1 回答 1

0

将此方法覆盖到您的适配器类,以便您可以在 onItemClick 中检索 id。

@Override
public long getItemId(int position) {
    return yourList.get(position);
}

在 onItemClick

final String ID = String.valueOf(lv.getAdapter().getItemId(arg2)); 
//long id = ((YourAdapter)parent.getAdapter()).getItemId(arg2);

请参阅Android OnItemClickListener long id 参数未提供字段 idview.getId() 在 OnItemClickListener 中返回错误 id

编辑:所以这里是奥利的变化:

final long id = ((EPListAdapter)arg0.getAdapter()).getItemId(arg2);

“在适配器上使用 .notifyDataSetChanged(); 很重要。否则它将不起作用。”

于 2013-05-01T14:15:13.370 回答