Xamarin iOS打开sqlite文件SQLite.SQLiteException:“文件不是数据库”

问题描述

我正在使用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对象确实具有以下信息

enter image description here

请帮助我,有什么想法吗?

解决方法

事实证明,这毕竟不是真正的sqlite文件。它是一个zip文件,但命名为sqlite文件,更疯狂的是,使用SQLiteAsyncConnection时,sql lite lib可以读取它。 即使是zip文件。 但是,一旦您触发查询,就会收到错误消息,指出它不是数据库。