我在xamarin.forms应用程序中将sqlite用作本地数据库。终止应用程序后,数据库将被清除。
将数据添加到db并从db读取是可以的,并且应用程序的行为还可以,但是在杀死了将应用程序置于后台一段时间后,db记录丢失了。
database = new WorkingTimeHistoryItemDatabase(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), "TimeStamps.db3"));
在卸载应用之前,我需要拥有这些数据
更新
这是WorkingTimeHistroryItemDatabase类
public class WorkingTimeHistoryItemDatabase
{
readonly SQLiteAsyncConnection database;
public WorkingTimeHistoryItemDatabase(string dbPath)
{
database = new SQLiteAsyncConnection(dbPath);
database.CreateTableAsync<TimeRecord>().Wait();
}
public Task<List<TimeRecord>> GetItemsAsync()
{
return database.Table<TimeRecord>().ToListAsync();
}
//public Task<List<TimeRecord>> GetItemsNotDoneAsync()
//{
// return database.QueryAsync<TimeRecord>("SELECT * FROM [TodoItem] WHERE [Done] = 0");
//}
public Task<List<TimeRecord>> GetItemAsync(string id)
{
return database.Table<TimeRecord>().Where(i => i.dateOnly == id).ToListAsync();
}
public Task<TimeRecord> GetRecentIn()
{
return database.Table<TimeRecord>().Where(i => i.inorout == "In").OrderByDescending(i => i.datetime).FirstOrDefaultAsync();
}
public Task<TimeRecord> GetRecentOut()
{
return database.Table<TimeRecord>().Where(i => i.inorout == "Out").OrderByDescending(i => i.datetime).FirstOrDefaultAsync();
}
public Task<int> SaveItemAsync(TimeRecord item)
{
return database.InsertAsync(item);
}
public Task<int> DeleteItemAsync(TimeRecord item)
{
return database.DeleteAsync(item);
}
}
答案 0 :(得分:2)
最好的方法是使用“ ApplicationData”文件夹。它将保留您的应用程序特定数据,并且OS知道有一些由第三方管理的内容。
答案 1 :(得分:0)
答案 2 :(得分:0)
我已将文件夹路径更改为“个人”。似乎现在可以正常工作。
database = new WorkingTimeHistoryItemDatabase(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal), "TimeStamps.db3"));