c# - Xamarin/SQLite/C# - 如何使用菜单项删除从列表视图和 SQLite 表中删除一行
问题描述
问题:所以这在编码论坛上并不是一个不常见的问题,但似乎人们应用删除按钮的方式有很多种,经过几天的尝试,我正在就我的方法征求一些建议。
我有一个简单的应用程序,它需要一些用户输入并用它来计算假期天数。我设置了一个简单的 SQLite db 来处理新条目:
public class LeaveEntry
{
[PrimaryKey, AutoIncrement]
public int ID { get; set; }
public string Date { get; set; }
public string Hours { get; set; }
public string Days { get; set; }
}
然后我在这个类中设置数据库连接并创建一些保存和删除方法:
public class Database
{
readonly SQLiteAsyncConnection _database;
public Database (string dbPath)
{
_database = new SQLiteAsyncConnection(dbPath);
_database.CreateTableAsync<LeaveEntry>().Wait();
}
public Task<List<LeaveEntry>> GetLeaveEntryAsync()
{
return _database.Table<LeaveEntry>().ToListAsync();
}
public Task<int> SaveLeaveEntry(LeaveEntry leaveEntry)
{
return _database.InsertAsync(leaveEntry);
}
public Task<int> DeleteLeaveEntry(LeaveEntry leaveEntry)
{
return _database.DeleteAsync(leaveEntry);
}
}
使用 SaveLeaveEntry 方法,我可以成功地将休假条目添加到另一个页面上的列表视图中,但我无法删除它们。在此列表视图页面上,当用户持有列表视图项时,我添加了一个带有删除按钮的菜单项。当他们选择删除菜单项时,我目前将其设置为:
public void MenuItem_Clicked(object sender, EventArgs e)
{
LeaveEntry itemToDelete = ((sender as MenuItem).BindingContext as LeaveEntry);
// Unfinished code attempt
await App.Database.DeleteLeaveEntry(new LeaveEntry
{
ID = listView.SelectedItem.
});
}
在我看来,我正在尝试使用选定的项目引用从数据库中提取该项目,但它只是什么都不做。我知道我在这里遗漏了一些简单的东西,但在这个问题上有点筋疲力尽。任何帮助表示赞赏。如果需要,可以提供更多代码或信息。
解决方案
在我看来,我正在尝试使用选定的项目引用从数据库中提取该项目,但它只是什么都不做。
您应该使用当前持有的项目作为方法的参数,DeleteLeaveEntry
而不是创建一个新项目。
请尝试以下代码:
LeaveEntry itemToDelete = ((sender as MenuItem).BindingContext as LeaveEntry);
App.Database.DeleteLeaveEntry(itemToDelete);
笔记:
另外,如果你不触发ItemSelected
你listview
的事件,值listView.SelectedItem
将会是null
。
推荐阅读
- javascript - 如何对具有相同键的对象值求和并返回一个对象?
- r - 按组嵌套数据框,但在每个组中包含额外的行
- docker - 从两个不同的容器映射端口
- system-verilog - 有没有办法在测试结束时获得断言触发(失败)的次数
- sql - 如何在 BigQuery 中获取两个数组的交集
- java - java.sql.SQLSyntaxErrorException:用户缺少权限或找不到对象:YEAR
- cudd - “相同”的值出现在 ADD 的叶子中
- json - Akka HTTP:从抽象类型创建 HTTPResponse
- c++ - 如何在运行时正确地将指向派生类的 void* 转换为指向基类的 void*
- java - 使用 EasyMock 模拟新的 PrintWriter(String fileName)