【问题标题】:Can't delete SQLite Database entry with EditText and Button无法使用 EditText 和 Button 删除 SQLite 数据库条目
【发布时间】: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_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)"
        );

我做错了什么?提前谢谢你:))

【问题讨论】:

    标签: java android sqlite android-studio


    【解决方案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
    猜你喜欢
    • 2012-10-15
    • 2012-07-14
    • 1970-01-01
    • 2018-06-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多