我有一个列表视图,其中将显示我的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 ...
解决此问题的最佳解决方案是什么?
比你多!
答案 0 :(得分: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 parameter is not giving field id和view.getId() returning wrong id in OnItemClickListener
编辑:所以这是Oli的变化:
final long id = ((EPListAdapter)arg0.getAdapter()).getItemId(arg2);
“在适配器上使用.notifyDataSetChanged();很重要。否则它不会工作。”