无法使用编辑文本和按钮删除 SQLite 数据库条目



我正在尝试实现一个方法,因此我可以在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);

}

这是我在"活动"中调用的方法,当单击删除按钮时:

@Override
public void onClick(View v) {
[...]
else if (v.equals(_btnDelete)){
Integer val = Integer.parseInt(_etDelete.getText().toString());
db.deleteEntry(val);
}

这是EditText和按钮的布局:

<EditText
android:id="@+id/etDelete"
android:layout_width="match_parent"
android:layout_height="60dp"
android:layout_weight="1"
android:digits="0123456789"
android:inputType="number"
android:hint="Enter ID to delete"/>
<Button
android:id="@+id/btnDelete"
android:layout_width="180dp"
android:layout_height="60dp"
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)"
);

我做错了什么?提前感谢:((

试试这个:

public void deleteEntry(Integer entryid){
SQLiteDatabase db = this.getWritableDatabase();
db.delete("data", "entryid" + "='" + entryid + "'", null);
}

尽管">是最近才支持的,'最好表示SQL字符串。

尝试使用:-

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);
}

试试这个,它可能会帮助你

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();
}
}

最新更新