Я использовал sqlite в качестве локальной базы данных в приложении xamarin.forms. После уничтожения приложения база данных очищается.
Добавление данных в базу данных и чтение из базы данных работает, и приложение работает нормально, но после того, как вы убили приложение на некоторое время в фоновом режиме, записи базы данных были потеряны.
database = new WorkingTimeHistoryItemDatabase(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), "TimeStamps.db3"));
Мне нужны эти данные, пока приложение не будет удалено
UPDATE
это класс 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);
}
}