Javascript Phonegap SQLite错误23未授权 资源:
设备/框架信息: Nexus4-Android 4.2.2 Phonegap 2.9.0 还使用UI的引导库 我遵循了PhoneGap 2.9版教程中关于创建和管理数据库的内容。到目前为止,我几乎没有发现人们在试图写入数据库时谈论特定错误23的地方 我在尝试在执行insertTemplate函数的insertBtn的click函数之后写入数据库时出现此错误 当触发deleteBtn事件(执行deleteTemplate函数)时,尝试删除行时也会发生同样的情况 有什么建议吗 控制器文件: 我的函数文件:Javascript Phonegap SQLite错误23未授权 资源:,javascript,android,jquery,sqlite,cordova,Javascript,Android,Jquery,Sqlite,Cordova,设备/框架信息: Nexus4-Android 4.2.2 Phonegap 2.9.0 还使用UI的引导库 我遵循了PhoneGap 2.9版教程中关于创建和管理数据库的内容。到目前为止,我几乎没有发现人们在试图写入数据库时谈论特定错误23的地方 我在尝试在执行insertTemplate函数的insertBtn的click函数之后写入数据库时出现此错误 当触发deleteBtn事件(执行deleteTemplate函数)时,尝试删除行时也会发生同样的情况 有什么建议吗 控制器文件: 我的函数
刚进入这个阶段,我不得不卸载这个应用程序,并重新制作它,同时也改变了版本,但我不认为这样做了。
因此每次调试时我都会卸载应用程序。如果你每次都要插入项目,这可能会很烦人,但至少解决了它。我不确定该建议什么来解决这个问题,但看起来PhoneGap正在尝试使用Android的WebSQL本机实现-阅读这里的具体问题-@Ross it说问题已经解决,它发生在2.2年是的,我相信它被标记为已解决,因为它无法复制。由于您使用的是最新版本的PhoneGap,因此它显然无法解决。很抱歉,我不是想指出问题是否得到解决,我只是想帮助您调查问题并收集一些信息来解决问题。您能解释一下真正的原因吗?我已经尝试了给定的链接,但不适用于我,这是我的理论。结果表明,当您重新安装应用程序时,本地数据不会被清除。然后,如果在创建数据库后清除它,它实际上就不存在了,这就是为什么这样做的原因。这个问题本身就是一个bug,它被认为不再存在了。当然,除非您试图访问不同版本的数据库。对不起,我不知道了。
var databaseName = "blackbriar";
var version = 1;
var displayName = "lctv";
var size = 2097152; // two megabytes
var db = null;
$(document).ready(function(event){
// Gets shell for database
db = window.openDatabase("Database", "1.0", "Cordova Demo", 200000);
db.transaction(populateDb, errorCb, successCb);
db.transaction(loadTemplates, errorCb, successCb);
$('#insertBtn').click(function(event){
db.transaction(insertTemplate, errorCb, successCb);
});
$('#back').click(function(event){
$('#templates').show();
$('#templateEdit').hide();
$('#back').hide();
});
$('#deleteBtn').click(function(event){
db.transaction(deleteTemplate, errorCb, successCb);
$('#back').click();
});
});
$(document).on('click', '.pill', function(event){
// If window width is greater than 480px, isMobile variable is false
var isMobile = $(window).width() > 480 ? false : true;
$('#currentId').text($(this).attr('tempid'));
db.transaction(getTemplateById, errorCb, successCb);
if($('#currentId').text() == "-1"){
$('#insertBtn').show();
$('#saveBtn').hide();
$('#deleteBtn').hide();
$('#clearBtn').show();
} else {
$('#insertBtn').hide();
$('#saveBtn').show();
$('#deleteBtn').show();
$('#clearBtn').hide();
}
// Checks if pill is active for UI changes
if($(this).hasClass('active')){
$(this).removeClass('active');
if(!isMobile){$(this).find('.temp').attr('style', 'color: black;');}
} else {
$('.pill').removeClass('active');
$('.pill').find('.temp').attr('style', 'color: black;');
$(this).addClass('active');
if(!isMobile){$(this).find('.temp').attr('style', 'color: white;');}
}
if(isMobile) {
$('#templates').hide();
$('#templateEdit').show();
$('#back').show();
}
});
function getShell(databaseName, version, displayName, size) {
return window.openDatabase(databaseName, version, displayName, size);
}
function populateDb(tx) {
tx.executeSql('CREATE TABLE IF NOT EXISTS templates (id INTEGER PRIMARY KEY AUTOINCREMENT, templateName, description, campus, account, department, programName, projectId, taskId)');
}
function errorCb(error) {
alert("Error processing SQL: "+error.code);
}
function successCb() {
alert("Success!");
}
function insertTemplate(tx) {
var templateName = $('#templateName').val();
var description = $('#descriptionField').val();
var campus = $('#campusField').val();
var account = $('#accountField').val();
var department = $('#departmentField').val();
var programName = $('#programNameField').val();
var projectId = $('#projectIdField').val();
var taskId = $('#taskIdField').val();
tx.executeSql('INSERT INTO templates (templateName, description, campus, account, department, programName, projectId, taskId) VALUES ('
+'"'+templateName+'"'+', '
+'"'+description+'"'+', '
+'"'+campus+'"'+', '
+'"'+account+'"'+', '
+'"'+department+'"'+', '
+'"'+programName+'"'+', '
+'"'+projectId+'"'+', '
+'"'+taskId+'"'
+')');
}
function loadTemplates(tx) {
tx.executeSql('SELECT * from templates', [], templatesSuccess, errorCb);
}
function templatesSuccess(tx, results) {
var length = results.rows.length;
$('#templateUl').html('');
$('#templateUl').append('<li class="templi"><a class="pill" tempid="-1"><text class="temp"><i style="color: green;" class="icon-plus"></i> Create</text></a></li>');
for(var i = 0; i < length; i++) {
$('#templateUl').append('<li class="templi"><a class="pill" tempid="'+results.rows.item(i).id+'"><text class="temp">'+results.rows.item(i).templateName+'</text></a></li>');
}
}
function getTemplateById(tx) {
var currentId = $('#currentId').text();
tx.executeSql('SELECT * FROM templates WHERE id = '+currentId, [], loadTemplateSuccess, errorCb);
}
function loadTemplateSuccess(tx, results) {
if(results.rows.length > 0){
var template = results.rows.item(0);
var templateName = $('#templateName').val(template.templateName);
var description = $('#descriptionField').val(template.description);
var campus = $('#campusField').val(template.campus);
var account = $('#accountField').val(template.account);
var department = $('#departmentField').val(template.department);
var programName = $('#programNameField').val(template.programName);
var projectId = $('#projectIdField').val(template.projectId);
var taskId = $('#taskIdField').val(template.taskId);
} else {
var templateName = $('#templateName').val('');
var description = $('#descriptionField').val('');
var campus = $('#campusField').val('');
var account = $('#accountField').val('');
var department = $('#departmentField').val('');
var programName = $('#programNameField').val('');
var projectId = $('#projectIdField').val('');
var taskId = $('#taskIdField').val('');
}
}
function deleteTemplate(tx) {
var currentId = $('#currentId').text();
alert(currentId);
tx.executeSql('DELETE FROM templates', [], templatesSuccess, errorCb);
alert("Authorize!!!");
}