新事务正在等待开放操作sqlite [英] new transaction is waiting for open operation sqlite

查看:800
本文介绍了新事务正在等待开放操作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 s​​qlite存储插件

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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆