gpt4 book ai didi

ios - 新交易等待开启操作

转载 作者:行者123 更新时间:2023-12-01 17:32:24 25 4
gpt4 key购买 nike

我正在使用 cordova+angular.js+onsenui 创建移动应用程序。

我想要做的是打开预先填充的数据库,执行选择语句并将结果显示为列表。我用litehelpers/cordova-sqlite-ext操作数据库的插件。

但是当我使用 iOS 模拟器运行应用程序并在 Safari 控制台中查看日志时,会记录“新事务正在等待打开操作”。

控制台日志如下:

database already open: test.db

test1

new transaction is waiting for open operation

DB opened: test.db

我的代码(index.js)如下。

angular.module('app').controller('listController', function ($scope) {


var items = [];
ons.ready(function() {
db = sqlitePlugin.openDatabase({name: "test.db", location: 2, createFromLocation: 1});
console.log('test1');

db.readTransaction(function(tx) {
console.log('test2');
var sql = "SELECT id, title, status FROM items";
tx.executeSql(sql, [], function(tx, response) {
for (var i = 0; i < response.rows.length; i++) {
var row = response.rows.item(i);
items.push({title:"Item Title", label:"6h", desc:row.title});
}
}, function(error) {
console.log('SELECT error: ' + error.message);
});
}, errorCB, successCB);
});

function successCB() {
$scope.itemTable = items;
$scope.$apply();
}

function errorCB(err) {
alert("Error processing SQL: "+err.code);
}

$scope.showDetail = function(item) {
console.log('showDetail');
myNavigator.pushPage("detail.html", {item: item});
};
});

有人知道如何解决这个问题吗?

我很感激任何建议和提示。

最佳答案

对于遇到同样问题的人,我写下我的解决方案。

我将插件更改为以下内容。

我的代码如下。

function onDeviceReady() {
// Handle the Cordova pause and resume events
document.addEventListener( 'pause', onPause.bind( this ), false );
document.addEventListener( 'resume', onResume.bind( this ), false );
dbcopy();
}

function dbcopy()
{
window.plugins.sqlDB.copy("test.db", 0, copysuccess, copyerror);
}

function copysuccess()
{
//open db and run your queries
//alert('copysuccess');
openDatabase();
}

function openDatabase()
{
db = window.sqlitePlugin.openDatabase({name: "test.db"});
}

function copyerror(e)
{
//db already exists or problem in copying the db file. Check the Log.
console.log("Error Code = "+JSON.stringify(e));
//e.code = 516 => if db exists
if (e.code == '516') {
openDatabase();
}
}

angular.module('app').controller('listController', function ($scope) {

var items = [];
ons.ready(function() {
if (db === null) {
openDatabase();
}
db.transaction(function(tx) {
var sql = "SELECT * FROM items;";
tx.executeSql(sql, [], function(tx, response) {
for (var i = 0; i < response.rows.length; i++) {
var row = response.rows.item(i);
items.push({title:row.title, label:row.label, desc:row.desc});
}
console.log("res.rows.item(0).title: " + response.rows.item(0).title);
}, errorCB);
}, errorCB, successCB);
});

function successCB() {
$scope.itemTable = items;
$scope.$apply();
}

function errorCB(err) {
alert("Error processing SQL: "+err.message);
}

$scope.showDetail = function(item) {
console.log('showDetail');
myNavigator.pushPage("detail.html", {item: item});
};
});

关于ios - 新交易等待开启操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35809791/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com