将数据从异步请求添加到 WebSQL 数据库时出错

Error when adding data from an asynchronous request to a WebSQL database

本文关键字:WebSQL 数据库 出错 添加 数据 异步 请求      更新时间:2023-09-26

我正在使用使用设备日历的Phonegap/Cordova为Android构建应用程序。我写了一个插件("Calify"),可以将事件添加到设备日历中,效果很好。但是,我正在尝试将插件返回的设备日历事件 ID 添加到 Web-SQL 数据库中的记录中,但这给了我以下错误(在 Android 模拟器中运行):

file:///android_asset/www/cordova-2.2.0.js: Line 1090 : processMessage failed: Message: S01 Calify507282772 s[{"id":191,"calid":615}]
file:///android_asset/www/cordova-2.2.0.js: Line 1091 : processMessage failed: Error: Error: INVALID_STATE_ERR: DOM Exception 11

这是我的代码的样子。

window.addEvent(function(insertions){
    data = JSON.parse(insertions);
    console.log(insertions);
    event_id = data[0]['calid'];
    id = data[0]['id'];
    tx.executeSql('UPDATE AFSPRAKEN SET eventID=? WHERE id=' + id, [event_id]);
}, [calendarID, [{start: start.getTime(), end: end.getTime(), title: event_title}]]);
"

插入"日志为我提供了所需的结果,以及分别记录"event_id"和"id"。它似乎与数据库插入有关(这也是异步的)。请注意,此函数在数据库事务中运行,这是必需的,因为我在此日历事件函数之外也运行其他一些查询。注释掉插入查询可使代码运行时没有错误。

DOM 异常 11 似乎意味着对象(我猜是"插入"?)不再可访问,也许与此有关。

我认为我犯的错误现在很明显,所以对于通过谷歌找到这个问题的每个人(错误消息并没有真正指向正确的方向),这就是我的代码给出错误的原因:

数据库事务是异步的,以及 Phonegap 插件。Phonegap 函数在数据库事务外部完成,因此无法在该事务内运行数据库查询。这可以通过多种方式解决:

  • 在Phonegap通信的完整功能中打开新的数据库事务
  • 像我一样,在数据库事务后连接Phonegap插件