无法使用 EditText 和 Button 删除 SQLite 数据库条目
Posted
技术标签:
【中文标题】无法使用 EditText 和 Button 删除 SQLite 数据库条目【英文标题】:Can't delete SQLite Database entry with EditText and Button 【发布时间】:2021-12-22 22:04:00 【问题描述】:我正在尝试实现一个方法,因此我可以在 edittext 字段中输入一个值(整数)并单击一个按钮来删除一个 SQLite 数据库条目。不过,我似乎无法让它工作。
这是 DatabaseManager 类中的方法:
public void deleteEntry(Integer entryid)
SQLiteDatabase db = this.getWritableDatabase();
db.delete("data", "entryid" + "=\"" + entryid + "\"", null);
这是活动类中的声明:
@Override
protected void onCreate(Bundle savedInstanceState)
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_history);
_btnDelete = (Button) findViewById(R.id.btnDelete);
_etDelete = (EditText) findViewById(R.id.etDelete);
db = new DatabaseManager(this);
_btnDelete.setOnClickListener(this);
这是我在 Activity 中调用的方法,当单击删除按钮时:
@Override
public void onClick(View v)
[...]
else if (v.equals(_btnDelete))
Integer val = Integer.parseInt(_etDelete.getText().toString());
db.deleteEntry(val);
这里是 EditText 和 Button 的布局:
<EditText
android:id="@+id/etDelete"
android:layout_
android:layout_
android:layout_weight="1"
android:digits="0123456789"
android:inputType="number"
android:hint="Enter ID to delete"/>
<Button
android:id="@+id/btnDelete"
android:layout_
android:layout_
android:layout_weight="1"
android:text="Delete"/>
最后是数据库方案:
public void onCreate(SQLiteDatabase db)
try
db.execSQL("CREATE TABLE data (" +
"entryid INTEGER PRIMARY KEY AUTOINCREMENT," +
"name TEXT," +
"weight INTEGER," +
"reps INTEGER," +
"entrytime TEXT)"
);
我做错了什么?提前谢谢你:))
【问题讨论】:
【参考方案1】:试试这个:
public void deleteEntry(Integer entryid)
SQLiteDatabase db = this.getWritableDatabase();
db.delete("data", "entryid" + "='" + entryid + "'", null);
虽然最近才支持 ",但最好用 ' 来表示 SQL 字符串。
【讨论】:
不幸的是不起作用,单击按钮后条目仍然存在。我现在尝试像这样实现它:public void deleteEntry(Integer entryid) SQLiteDatabase db = this.getWritableDatabase(); db.delete("data", "entryid" + "='" + entryid + "'", null);
和 db.deleteEntry(Integer.valueOf(_etDelete.getText().toString()));
但这似乎也不起作用。【参考方案2】:
尝试使用:-
db.delete("data", "entryid=?", new String[]String.valueOf(entryid));
重新评论:-
不幸的是,这并没有改变任何东西,....
我相信你也需要改变:-
else if (v.equals(_btnDelete))
Integer val = Integer.parseInt(_etDelete.getText().toString());
db.deleteEntry(val);
到
else if (view.getId() == R.id.btnDelete)
Integer val = Integer.parseInt(_etDelete.getText().toString());
db.deleteEntry(val);
【讨论】:
不幸的是,这并没有改变任何东西,我现在将 DatabaseManager 中的方法更改为:public Integer deleteEntry(String entryid) SQLiteDatabase db = this.getWritableDatabase(); return db.delete("data", "entryid=?", new String[]String.valueOf(entryid));
,并在活动中这样调用它:else if (v.equals(_btnDelete)) Integer deletedRows = db.deleteEntry(_etDelete.getText().toString());
,但它仍然不起作用。
@David 查看编辑后的答案。【参考方案3】:
试试这个可能对你有帮助
public void removeSingleItem(String id)
SQLiteDatabase database = this.getWritableDatabase();
long result = database.delete(TableName, "id=?", new String[]id);
if (result == -1)
Toast.makeText(context, "Item Not Deleted", Toast.LENGTH_SHORT).show();
else
Toast.makeText(context, "Item Deleted Successfully", Toast.LENGTH_SHORT).show();
【讨论】:
您的答案可以通过额外的支持信息得到改进。请edit 添加更多详细信息,例如引用或文档,以便其他人可以确认您的答案是正确的。你可以找到更多关于如何写好答案的信息in the help center。以上是关于无法使用 EditText 和 Button 删除 SQLite 数据库条目的主要内容,如果未能解决你的问题,请参考以下文章
使用 Button 将 EditText 保存到文件 - Android、Java