我实际上正在开发一个正在读取(而不是写入).mbtiles 文件的cordova 应用程序。那是一个用瓷砖归档的数据库,以便显示带有传单的离线地图。
与文件有关的所有内容(称为 test.mbtiles)都在工作:下载和打开。但是还有一个大问题。我无法阅读表格。这是我的代码的非功能示例:
getTileUrl: function (tilePoint, callBack) {
var x = tilePoint.x;
var y = tilePoint.y;
var z = tilePoint.z;
var base64Prefix = 'data:image/png;base64,';
var db2 = new window.sqlitePlugin.openDatabase({name: 'test.mbtiles'});
db2.transaction(function(tx) {
tx.executeSql("SELECT tile_data FROM images INNER JOIN map ON images.tile_id = map.tile_id WHERE zoom_level = ? AND tile_column = ? AND tile_row = ?", [z, x, y], function (tx, res) {
if(res.rows.length>0) {
console.log("success");
var src = base64Prefix + res.rows.item(0).tile_data;
callBack(src);
}
else {
console.log("response : no data");
}
}, function (tx, er) {
console.log('error with executeSql : ', er.message);
return;
});
});
}
所以现在每次我尝试使用离线地图(使用设备上存在的 test.mbtiles 中的图块)时,我都会收到此错误:
error with executeSql : no such table: images (code 1): , while compiling: SELECT tile_data FROM images INNER JOIN map ON images.tile_id = map.tile_id WHERE zoom_level = ? AND tile_column = ? AND tile_row = ?
所以我假设我得到的文件 test.mbtiles 不好,因为它没有任何images
表。但这是错误的。我用来SQLite Database Browser
查看我的数据库方案,发现images
表在这里并填充了正确的数据。
有没有其他人有这个错误并且知道如何解决它?
顺便说一句,我正在使用最新版本的 SQLite Plugin 和 Cordova,主要在 android 上进行测试(如果 android 工作,将移植到 ios)。并且我想尽可能只使用 .js 文件,不添加任何 java 类等(会破坏整个工作流程)。
谢谢。