在sqlite中保存的xamarin应用数据已清除

时间:2019-06-02 16:05:09

标签: c# sqlite xamarin xamarin.forms

我在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);
        }
    }

3 个答案:

答案 0 :(得分:2)

最好的方法是使用“ ApplicationData”文件夹。它将保留您的应用程序特定数据,并且OS知道有一些由第三方管理的内容。

答案 1 :(得分:0)

如果要在UWP上进行测试,请检查您是否没有“卸载然后重新安装我的程序包”。选项已选中。在UWP项目>属性>调试>启动选项中。

UninstallCheckBox

答案 2 :(得分:0)

我已将文件夹路径更改为“个人”。似乎现在可以正常工作。

database = new WorkingTimeHistoryItemDatabase(Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal), "TimeStamps.db3"));