L
loriot
Neues Mitglied
- 1
Hallo,
ich bin noch ziemlicher Anfänger (haben vor Jahren eine Zeitlang als Hobby J2ME programmiert).
Zur Zeit schreibe ich mir ein kleines Programm um meine Arbeitszeiten zu erfassen. Die Einträge werden mit SQLite gespeichert und in einer Liste mittels einer Listactivity dargestellt.
Der entsprechende Code um die Liste zu füllen ist:
// DB Abfrage in den cursor laden
Cursor cursor = db.query(false,"buchungen",new String[]{"_id","buchung"},null,null,null,null,null,null);
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.buchungslist_item, cursor,new String[] {"buchung"}, new int[] { android.R.id.text1 });
setListAdapter(adapter);
Ich benutze dann ein ContextMenu um Optionen für jeden Eintrag auswählen zu können, z.Bsp einen Eintrag zu löschen. Der bisher einzige Weg, der mir dazu einfiel ist wie folgt:
public boolean onContextItemSelected(MenuItem item) {
info = (AdapterView.AdapterContextMenuInfo) item.getMenuInfo();
switch (item.getItemId()) {
case MENU_ITEM_DELETE: {
// getItem erwartet int nicht long und hat einen Versatz um 1
select = (int) info.id - 1;
// Den Cursor auf den ausgewählten Entry aus der Liste setzen:
Cursor cursor = (Cursor) getListAdapter().getItem(select);
// Zur Kontrolle die Werte des ausgewählten Entry nochmals ausgeben:
String the_id = cursor.getString(0); // Die _id des Eintrags
String datum = cursor.getString(1); // Den Text des Eintrags
final Toast hinweis = Toast.makeText(this , "Deleting Entry ("+the_id+"):+datum,Toast.LENGTH_LONG);
hinweis.show();
// Jetzt wird der Eintrag gelöscht
db.delete("buchungen","_id = ?", new String[]{the_id});
Mein Problem ist jetzt, das das ganze einmal wunderbar funktioniert. Allerdings werden bei diesem Vorgang weder der Cursor noch der ListAdapater davon informiert, dass Elemente gelöscht wurden, und beim nächten mal löschen, löscht man entweder ein falsches Element oder bekommt gar eine Runtime Exception.
Grund ist wohl, dass die Listen im Cursor oder im ListAdapter keinen Refresh erhalten und somit nichts von der geänderten Datenbank wissen.
Meine Frage ist nun, wie ich das am Besten lösen kann.
ich bin noch ziemlicher Anfänger (haben vor Jahren eine Zeitlang als Hobby J2ME programmiert).
Zur Zeit schreibe ich mir ein kleines Programm um meine Arbeitszeiten zu erfassen. Die Einträge werden mit SQLite gespeichert und in einer Liste mittels einer Listactivity dargestellt.
Der entsprechende Code um die Liste zu füllen ist:
// DB Abfrage in den cursor laden
Cursor cursor = db.query(false,"buchungen",new String[]{"_id","buchung"},null,null,null,null,null,null);
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.buchungslist_item, cursor,new String[] {"buchung"}, new int[] { android.R.id.text1 });
setListAdapter(adapter);
Ich benutze dann ein ContextMenu um Optionen für jeden Eintrag auswählen zu können, z.Bsp einen Eintrag zu löschen. Der bisher einzige Weg, der mir dazu einfiel ist wie folgt:
public boolean onContextItemSelected(MenuItem item) {
info = (AdapterView.AdapterContextMenuInfo) item.getMenuInfo();
switch (item.getItemId()) {
case MENU_ITEM_DELETE: {
// getItem erwartet int nicht long und hat einen Versatz um 1
select = (int) info.id - 1;
// Den Cursor auf den ausgewählten Entry aus der Liste setzen:
Cursor cursor = (Cursor) getListAdapter().getItem(select);
// Zur Kontrolle die Werte des ausgewählten Entry nochmals ausgeben:
String the_id = cursor.getString(0); // Die _id des Eintrags
String datum = cursor.getString(1); // Den Text des Eintrags
final Toast hinweis = Toast.makeText(this , "Deleting Entry ("+the_id+"):+datum,Toast.LENGTH_LONG);
hinweis.show();
// Jetzt wird der Eintrag gelöscht
db.delete("buchungen","_id = ?", new String[]{the_id});
Mein Problem ist jetzt, das das ganze einmal wunderbar funktioniert. Allerdings werden bei diesem Vorgang weder der Cursor noch der ListAdapater davon informiert, dass Elemente gelöscht wurden, und beim nächten mal löschen, löscht man entweder ein falsches Element oder bekommt gar eine Runtime Exception.
Grund ist wohl, dass die Listen im Cursor oder im ListAdapter keinen Refresh erhalten und somit nichts von der geänderten Datenbank wissen.
Meine Frage ist nun, wie ich das am Besten lösen kann.