【发布时间】: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