新事务正在等待开放操作sqlite [英] new transaction is waiting for open operation sqlite
问题描述
我正在使用此插件: https://github.com/litehelpers/Cordova-sqlite -storage
我在进行数据库事务时遇到上面的问题。事实上,在我的项目中有这么多交易在同一时间从js以及java结束。
I'm getting above issue in my project while doing DB transactions. Actually there so many transactions in my project at same time from js as well as java end.
任何人都可以帮助吗?
Can anyone please help? I'm stuck here from last 3 days.
以下是我的代码(只有1条查询):
Below is my code (just 1 query) :
function createTable(latWS,longWS,empId) {
window.sqlitePlugin.openDatabase({name: 'test.db', location: 'default'}, function(db) {
db.transaction(function(tx) {
tx.executeSql('CREATE TABLE IF NOT EXISTS test (loc_emp_lat, loc_emp_long, loc_emp_accuracy, loc_emp_local_time)');
}, function(err) {
console.log('Open database ERROR: ' + JSON.stringify(err));
});
});
setTimeout(insertIntoLogTable(latWS,longWS,empId),500);
}
我已经检查过,它不会出现错误信息。
I have checked, it is not going in error message.
我使用的版本:
cordova-sqlite-storage 1.4.7Cordova sqlite存储插件
I'm using version : cordova-sqlite-storage 1.4.7 "Cordova sqlite storage plugin"
我的Cordova Android版本是:4.1.1
My Cordova Android version is : 4.1.1
推荐答案
您需要在创建表之前使用延迟,例如:
you need to use a delay before creating table ,example:
window.sqlitePlugin.openDatabase({name: 'test.db', location: 'default'});
timeout(function(){
tx.executeSql('CREATE TABLE IF NOT EXISTS test (loc_emp_lat, loc_emp_long, loc_emp_accuracy, loc_emp_local_time)');
},4000);
这篇关于新事务正在等待开放操作sqlite的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!