我想用sqlite做一个待办事项列表,当我在一个项目上按了很久,它就会从列表中被删除(同时也从数据库中删除)。但我无法实现,不知道如何删除(我是个新手)。我可以在setOnItemLongClickListener中做什么来删除数据库中的值? 这是我的MainActivity.java
import androidx.appcompat.app.AppCompatActivity;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.Toast;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
private ArrayList<String> items;
private ArrayAdapter<String> itemsAdapter;
private ListView lvItems;
private EditText e;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final DatabaseHelper helper = new DatabaseHelper(this);
lvItems = (ListView)findViewById(R.id.lvItems);
items = helper.getAllAcontacts();
itemsAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, items);
lvItems.setAdapter(itemsAdapter);
e = (EditText)findViewById(R.id.etNewItem);
Button add = (Button)findViewById(R.id.btnAddItem);
add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(!e.getText().toString().isEmpty()) {
if (helper.insert(e.getText().toString())){
Toast.makeText(MainActivity.this, "Inserted", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(MainActivity.this, "Not Inserted", Toast.LENGTH_SHORT).show();
else{
e.setError("Enter To Do List Item");
items.clear();
items.addAll(helper.getAllAcontacts());
itemsAdapter.notifyDataSetChanged();
lvItems.invalidateViews();
lvItems.refreshDrawableState();
e.setText("");
setupListViewListener();
private void setupListViewListener() {
lvItems.setOnItemLongClickListener(
new AdapterView.OnItemLongClickListener() {
@Override
public boolean onItemLongClick(AdapterView<?> adapter,
View item, int pos, long id) {
// Remove the item within array at position
items.remove(pos);
itemsAdapter.notifyDataSetChanged();
// Return true consumes the long click event (marks it handled)
return true;
而这是我的数据库删除功能。
public void deleteItem(long itemId) {
SQLiteDatabase db = this.getWritableDatabase();
db.delete(DatabaseHelper.LIST_TABLE_NAME, "_id = ?",
new String[] { String.valueOf(itemId) });