android - 如何删除 SQL 数据库中的项目?

标签 android listview android-studio delete-row

<分区>

我知道有很多主题或多或少相同的话题,但没有一个能涵盖我的情况:

我有一个删除按钮,可以删除 listView 中的一个项目,但是当您关闭应用程序并重新打开它时,这些项目会重新出现。我不知道如何解决这个问题。

DatabaseHelper.java

public class DatabaseHelper extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "todo.db";
public static final int DATABASE_VERSION = 1;
public static final String ITEMS_TABLE = "items";

private static DatabaseHelper instance = null;

public static DatabaseHelper getInstance(Context context) {

    if(instance == null) {
        instance = new DatabaseHelper(context);
    }
    return instance;
}

private DatabaseHelper(Context context) {
    super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
public void onCreate(SQLiteDatabase db) {

    String createQuery = "CREATE TABLE " + ITEMS_TABLE + " (" +
            "_id INTEGER PRIMARY KEY AUTOINCREMENT," +
            "description TEXT NOT NULL, " +
            "completed INTEGER NOT NULL DEFAULT 0)";
    db.execSQL(createQuery);
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

    }
}

该按钮工作正常,但它不会永久删除我不知道它是否是代码,或者它是否是我将它放在我的 MainActivity 中的位置,如果有人会告诉我会多赞赏。

MainActivity.java

 public class MainActivity extends AppCompatActivity {

private static final String LOG_TAG = "ToDoApp";

private ToDoListManager listManager;
private ToDoItemAdapter adapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    ListView todoList = (ListView) findViewById(R.id.todo_list);

    listManager = new ToDoListManager(getApplicationContext());

    adapter = new ToDoItemAdapter(
            this,
            listManager.getList()
    );

    todoList.setAdapter(adapter);

    ImageButton addButton = (ImageButton) findViewById(R.id.add_item);
    addButton.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            onAddButtonClick();
        }
    });
}

@Override
protected void onPause() {
    super.onPause();
}

private void onAddButtonClick() {
    AlertDialog.Builder builder = new AlertDialog.Builder(this);
    builder.setTitle(R.string.add_item);

    final EditText input = new EditText(this);
    input.setInputType(InputType.TYPE_CLASS_TEXT);
    builder.setView(input);

    builder.setPositiveButton(
            R.string.ok,
            new DialogInterface.OnClickListener() {

                @Override
                public void onClick(DialogInterface dialog, int which) {
                    ToDoItem item = new ToDoItem(
                            input.getText().toString(),
                            false
                    );
                    listManager.addItem(item);
                    adapter.swapItems(listManager.getList());
                }
            });

    builder.setNegativeButton(
            R.string.cancel,
            new DialogInterface.OnClickListener() {

                @Override
                public void onClick(DialogInterface dialog, int which) {
                    dialog.cancel();
                }
            });

    builder.show();
}

private class ToDoItemAdapter extends ArrayAdapter<ToDoItem> {

    private Context context;
    private List<ToDoItem> items;
    private LayoutInflater inflater;

    public ToDoItemAdapter(
            Context context,
            List<ToDoItem> items
    ) {
        super(context, -1, items);

        this.context = context;
        this.items = items;
        this.inflater = LayoutInflater.from(context);
    }

    public void swapItems(List<ToDoItem> items) {
        this.items = items;
        notifyDataSetChanged();
    }

    @Override
    public int getCount() {
        return items.size();
    }

    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {

        final ItemViewHolder holder;

        if(convertView == null) {

            convertView = inflater.inflate(R.layout.to_do_item_layout, parent, false);


            holder = new ItemViewHolder();
            holder.itemDescription = (TextView) convertView.findViewById(R.id.item);
            holder.itemState = (CheckBox) convertView.findViewById(R.id.checkBox);
            convertView.setTag(holder);
        }else {
            holder = (ItemViewHolder) convertView.getTag();
        }


       holder.itemDescription.setText(items.get(position).getDescription());
        holder.itemState.setChecked(items.get(position).isComplete());

        holder.itemState.setTag(items.get(position));

        convertView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                ToDoItem item = (ToDoItem) holder.itemState.getTag();
                item.toggleComplete();
                listManager.updateItem(item);
                notifyDataSetChanged();
            }
        });
        ImageButton deleteButton = (ImageButton) convertView.findViewById(R.id.delete_Button);
        deleteButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                items.remove(items.get(position));
                notifyDataSetChanged();
            }
        });

        holder.itemState.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                ToDoItem item = (ToDoItem) holder.itemState.getTag();
                item.toggleComplete();
                listManager.updateItem(item);
                notifyDataSetChanged();

            }
        });

        return convertView;
    }
}

public static class ItemViewHolder{
    public TextView itemDescription;
    public CheckBox itemState;
     }
 }

ToDoListManager.java

public class ToDoListManager {

private DatabaseHelper dbHelper;

public ToDoListManager(Context context) {

    dbHelper = DatabaseHelper.getInstance(context);
}

public List<ToDoItem> getList() {

    SQLiteDatabase db = dbHelper.getReadableDatabase();
    Cursor cursor = db.rawQuery(
            "SELECT * FROM " + DatabaseHelper.ITEMS_TABLE,
            null
    );

    List<ToDoItem> items = new ArrayList<>();

    if(cursor.moveToFirst()) {
        while(!cursor.isAfterLast()) {

            ToDoItem item = new ToDoItem(
                    cursor.getString(cursor.getColumnIndex("description")),
                    cursor.getInt(cursor.getColumnIndex("completed")) != 0,
                    cursor.getLong(cursor.getColumnIndex("_id"))
            );
            items.add(item);
            cursor.moveToNext();
        }
    }
    cursor.close();
    return items;
}

public void addItem(ToDoItem item) {

    ContentValues newItem = new ContentValues();
    newItem.put("description", item.getDescription());
    newItem.put("completed", item.isComplete());

    SQLiteDatabase db = dbHelper.getWritableDatabase();
    db.insert(DatabaseHelper.ITEMS_TABLE, null, newItem);


}

public void updateItem(ToDoItem item) {

    ContentValues editItem = new ContentValues();
    editItem.put("description", item.getDescription());
    editItem.put("completed", item.isComplete());

    SQLiteDatabase db = dbHelper.getWritableDatabase();

    String[] args = new String[] { String.valueOf(item.getId()) };

    db.update(DatabaseHelper.ITEMS_TABLE, editItem, "_id=?", args);

  }
}

ToDoItem.java

public class ToDoItem {

private String description;
private boolean isComplete;
private long id;

public ToDoItem(String description, boolean isComplete) {
 this(description, isComplete, -1);
}
public ToDoItem(String description,boolean isComplete,long id) {
    this.description = description;
    this.isComplete = isComplete;
    this.id = id;
}

public String getDescription() {
    return description;
}

public boolean isComplete() {
    return isComplete;
}

public void toggleComplete() {
    isComplete = !isComplete;
}
public long getId() {return id;}

@Override
public String toString() {

    return getDescription();
  }
}

最佳答案

您只需在适配器类中删除导致项目从当前 listView 中删除的项目。但是您的 ToDoListManager.java 中没有任何函数可以从数据库中删除项目。从 listView 中删除不会影响您的数据库项目。

您可以将此函数添加到您的ToDoListManager.java

public void deleteItem(long itemId) {

    SQLiteDatabase db = dbHelper.getWritableDatabase();
    db.delete(DatabaseHelper.ITEMS_TABLE, "_id = ?",
            new String[] { String.valueOf(itemId) }); 
}

然后从删除按钮的 onClick 中调用它,就像这样

ImageButton deleteButton = (ImageButton) convertView.findViewById(R.id.delete_Button);
        deleteButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                long itemId = items.get(position).getId();
                items.remove(items.get(position));
                listManager.deleteItem(itemId);
                notifyDataSetChanged();
            }
        });

关于android - 如何删除 SQL 数据库中的项目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38864003/

相关文章:

android - 将图像从安卓客户端发送到谷歌应用引擎

android - ListView - ViewHolder 设计的错误回收行为

android - 尝试在 firebase 上填充 ListView 时没有 setter /字段

android - 如何给ListView添加页眉和页脚(Android XE5)

java - 尝试在 Android Studio 中请求具有位置权限的对话框,但它不起作用

android - Activity 未找到异常 : Shortcut could not be started

xml - 是否有任何 Android XML 文档?

android - 警告:API 'variant.getMergeResources()'已作废,并已替换为 'variant.getMergeResourcesProvider()'

android - 使用新的 kotlin 1.1 构建错误,kapt 无法解析数据绑定(bind)参数

android - 如何从本地机器安装 android sdk 插件?