HTML5 / Javascript sqliteを使用して、WebサイトのRSSフィードを取得してデータベースに保存するWebアプリケーションを開発しています。
これは私のコードです
function createPosts(title,author,content,contentSnippet,publishedDate,img_destaque){
var oldPost = checkIfExists(publishedDate);
console.log(oldPost);
if(!oldPost){
var query = "insert into mytable (titulo, data, autor, img_destaque,descricao,postagem) VALUES (?, ?, ?, ?, ?, ?);";
try {
localDB.transaction(function(transaction){
transaction.executeSql(query, [title, publishedDate, author, img_destaque, contentSnippet, content], function(transaction, results){
if (!results.rowsAffected) {
updateStatus("Error, not data inserted");
}
else {
updateStatus("Data inserted, id: " + results.insertId);
}
}, errorHandler);
});
}
catch (e) {
updateStatus("Error: " + e + ".");
}
}
else{
updateStatus("Error: Post already exists");
}
}
そしてこれは関数checkIfExistsです
function checkIfExists(publishedDate){
var query = "SELECT * FROM mytable;";
var returnStatus;
try {
localDB.transaction(function(transaction){
transaction.executeSql(query, [], function(transaction, results){
for (var i = 0; i < results.rows.length; i++) {
var row = results.rows.item(i);
if(publishedDate === row.data){
console.log(publishedDate+' '+row.data);
returnStatus = true;
}
}
if(i == results.rows.length){
returnStatus = false;
}
}, function(transaction, result){
returnStatus = true;
}, function(transaction, error){
updateStatus("Erro: " + error.code + "<br>Mensagem: " + error.message);
returnStatus = true;
});
});
}
catch (e) {
updateStatus("Error: SELECT não realizado " + e + ".");
returnStatus = true;
}
finally{
console.log(returnStatus);
return returnStatus;
}
}
しかし、動作していません。oldPostは常に「未定義」を返します。コンソールのログでは、関数が「oldPost」変数値を返した後にlocalDB.transactionが処理されることがわかります。どうすればこれを解決できますか?