Разница при использовании last_insert_row() в функции Javascript и в Инструменте запросов к БД?
Я создал таблицу в Google Gears (Sqlite):
db.execute('create table if not exists SPALINKS (link_id int PRIMARY KEY, sid1 int, sid2 int, label text, user text, Timestamp int');
При использовании инструмента запросов к базе данных Google Gears (в FF) INSERT с 'last-insert-rowid' работает нормально. Вставки из Javascript работают нормально, пока я не использую 'last-insert-rowid'. Но при использовании 'last-insert-rowid' это больше не работает:
var sql_stmt = 'INSERT INTO SPALINKS (link_id, sid1, sid2, label, user, Timestamp) VALUES (last_insert_rowid(),?,?,?,?,?)';
var arg_array = [sid1, sid2, label, user, creation_time];
db.execute(sql_stmt, arg_array);
Error: Database operation failed. ERROR: constraint failed DETAILS: constraint failed
Почему SQLite'last-insert-rowid' отлично работает с DB Tool, но не в операторе SQL, который создается и выполняется внутри функции Javascript?
2 ответа
Я думаю, что вы не должны использовать last_insert_rowid()
в этих ситуациях. Зачем просто делать INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT
,
// if you writing for android and you have something like this:
//document.addEventListener("deviceready", onDeviceReady, false);
//function onDeviceReady(){
// make sure you comment it if you debugging in browser
// connection to the databse
var db = window.openDatabase("demo.db", "1.0", "Demo Database", 200000);
// There is problem with SQLite recognize new Date() format so I include http://code.google.com/p/datejs/ library in my project and format the date to be recognizable by SQLite
function nowTime(){
return new Date().toString("yyyy-MM-dd HH:mm:ss");
}
function errorCallBack(err) {
alert("Error processing SQL: " + err.code);
}
function callBack(){
function readTransactionError(err){
alert('Read Transaction Error: ' + err);
}
// you can make your vars global if you want to use them out side of function!!!
function querySuccess(tx, results) {
var len = results.rows.length;
for(var i = 0; i < len; i++) {
var sid1Var = results.rows.item(i).sid1;
var sid2Var = results.rows.item(i).sid2;
var labelVar = results.rows.item(i).label;
var userNameVar = results.rows.item(i).userName;
var timeStampVar = results.rows.item(i).timeStamp;
}
}
tx.readTransaction('select * from SPALINKS;', [], querySuccess, readTransactionError);
}
function functionName(sid1, sid2, label, userName) {
db.transaction(function(tx) {
db.executeSql('create table if not exists SPALINKS (link_id int INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT, sid1, sid2, label, userName, timeStamp');
db.executeSql('insert into SPALINKS (sid1, sid2, label, userName, timeStamp) VALUES (?, ?, ?, ?, ?)', [sid1, sid2, label, userName, nowTime()], callBack, errorCallBack);
});
}
// assuming you use jQuery
$('#selectorID').click(function(){
functionName(sid1, sid2, label, userName);
});
Ты можешь использовать last_insert_rowid()
в ситуации, как UPDATE
:
function updateFunction() {
db.transaction(function(tx) {
tx.executeSql('update SPALINKS set timeStamp = "' + nowTime() + '" WHERE link_id = last_insert_rowid()');
});
}
Я надеюсь, что это сработает.
Кажется, проблема была в том, что соответствующий столбец не был определен как AUTOINCREMENT.