问题描述
我正在使用iOS应用程序在Xamarin Forms中工作。 代码成功下载了一个sqlite文件,我将文件移至以下位置: /var/mobile/Containers/Data/Application/787D3CB8-01E1-41BB-B786-972534E7F563/Documents/Data/test-file.sqlite
但是现在当我尝试使用以下代码打开它时,出现一个奇怪的错误: sqlite.sqliteException:“文件不是数据库”
数据库也未加密
这是我的代码:
var db = new sqliteAsyncConnection(_dbPath);
var versionlist = await db.QueryAsync<version_history>("SELECT * FROM version_history ORDER BY id DESC LIMIT 1")
执行QueryAsync后,我收到错误消息,该文件不是数据库。 但是db对象确实具有以下信息
请帮助我,有什么想法吗?
解决方法
事实证明,这毕竟不是真正的sqlite文件。它是一个zip文件,但命名为sqlite文件,更疯狂的是,使用SQLiteAsyncConnection时,sql lite lib可以读取它。 即使是zip文件。 但是,一旦您触发查询,就会收到错误消息,指出它不是数据库。