Дублирование хранилища cordova-sqlite при вставке в базу данных
Я новичок в использовании плагина cordova-sqlite-storage и использую модифицированную версию этого руководства по CRUD в своем приложении. База данных создается и открывается, и таблица создается успешно, но когда я вставляю один элемент, она дублируется несколько раз, а не просто вводится один раз. Все дублированные предметы имеют уникальные идентификаторы. Я пытался изменить его многими способами, но я застрял. Я не могу понять, почему он добавляет так много на вставке. Я ценю любую помощь!
Вот мой код (прошу прощения, если он немного длинный):
var myDB;
var vetDrugsId = 0;
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
myDB = window.sqlitePlugin.openDatabase({ name: "my.db", iosDatabaseLocation: 'Documents' });
CreateDB();
RefreshDrugs();
}
// Create Registration table in Sql Lite DB.
function CreateDB() {
myDB.transaction(function (transaction) {
transaction.executeSql('CREATE TABLE IF NOT EXISTS vetDrugs (Id integer primary key, title text, desc text, conc integer, dose integer, minimum integer, maximum integer)', [],
function (tx, result) {
console.log("Table created successfully");
},
function (error) {
console.log("Error occurred while creating the table.");
});
});
}
//Insert New Details (into SQLite Database)
$(document).on('click touchstart','#insert',function () {
var title=$("#title").val();
var desc=$("#desc").val();
var conc=parseInt($("#conc").val());
var dose=parseInt($("#dose").val());
var minimum=parseInt($("#minimum").val());
var maximum=parseInt($("#maximum").val());
myDB.transaction(function (transaction) {
if (vetDrugsId > 0) {
myDB.transaction(function (transaction) {
var executeQuery = "UPDATE vetDrugs SET title=?, desc=? ,conc=?, dose=?, minimum=?, maximum=? WHERE Id=?";
transaction.executeSql(executeQuery, [title,desc,conc,dose,minimum,maximum,vetDrugsId],
//On Success
function (tx, result) {
RefreshDrugs();
ClearControl();
$('#title,#desc,#conc,#dose,#minimum,#maximum').removeClass('error-border');
toastUpdate.open();
},
function (error) {
alert('Details not updated');
});
});
}
else {
var executeQuery = "INSERT INTO vetDrugs (title, desc, conc, dose, minimum, maximum) VALUES (?,?,?,?,?,?)";
transaction.executeSql(executeQuery, [title,desc,conc,dose,minimum,maximum]
, function (tx, result) {
RefreshDrugs();
ClearControl();
$('#title,#desc,#conc,#dose,#minimum,#maximum').removeClass('error-border');
//alert('Inserted successfully');
toastAdd.open();
},
function (error) {
//alert('Details not Inserted');
toastAddError.open();
});
}
});
});
// Load Data in Table from SQLite Database.
function RefreshDrugs() {
$("#TableData").html("");
myDB.transaction(function (transaction) {
transaction.executeSql('SELECT * FROM vetDrugs', [], function (tx, results) {
var len = results.rows.length, i;
$("#rowCount").html(len);
for (i = 0; i < len; i++) {
$('#TableData').append('<div class="table-row"><div class="column index hidden-print checkbox-cell"><a class="link actions-open" href="#" data-actions=".my-actions'+results.rows.item(i).Id+'"><i class="far fa-cog fa-fw fa-2x"></i></a><div class="actions-modal my-actions'+results.rows.item(i).Id+'"><div class="list"><ul><li><a href="#" class="edit list-button actions-close" id="edit_'+results.rows.item(i).Id+'"><i class="far fa-pencil fa-fw fa-lg"></i> Edit Drug</a></li><li><a id="delete_'+results.rows.item(i).Id+'" class="delete list-button actions-close" href="#" data-id="'+results.rows.item(i).Id+'"><i class="far fa-trash-alt fa-fw fa-lg"></i> Delete Drug</a></li><li><a class="btnCancel list-button actions-close" href="#"><i class="far fa-ban fa-fw fa-lg"></i> Cancel</a></li></ul></div></div></div><div class="wrapper attributes"><div class="wrapper drugName-concentration-condition-range"><div class="wrapper drugName-concentration"><div class="column drugName"><span class="drugTitle">'+results.rows.item(i).title+'</span> <p class="subtitle">'+results.rows.item(i).conc+' mg/ml</p> </div></div><div class="wrapper condition-range"><div class="column range">'+results.rows.item(i).desc+'</div></div></div></div><div class="wrapper results"><div class="column result"><input class="form-control form-control-sm drug" data-appendDose=" mg" data-appendVol=" ml" data-mg="#'+results.rows.item(i).Id+'mg" data-ml="#'+results.rows.item(i).Id+'ml" name="'+results.rows.item(i).Id+'name" type="number" data-conc="'+results.rows.item(i).conc+'" data-min="'+results.rows.item(i).minimum+'" data-max="'+results.rows.item(i).maximum+'" data-step="0.1" data-postfix="mg/kg" data-decimal="2" data-value="'+results.rows.item(i).dose+'" value="'+results.rows.item(i).dose+'" ><span class="error-message"><i class="fas fa-exclamation-triangle fa-sm fa-fw hidden-print" data-fa-transform="up-2"></i> Above Range</span></div><div class="column result"><span class="dosage bg-color-blue color-white" id="'+results.rows.item(i).Id+'mg" ></span></div><div class="column result"><span class="vol bg-color-green color-white" id="'+results.rows.item(i).Id+'ml" ></span></div></div></div>');
}
}, null);
});
}
// Get and Set Current Selected data.
$(document).on('click touchstart', '.edit', function () {
app.accordion.open("#panel10");
var delString = this.id;
var splitId = delString.split("_");
var curId = splitId[1];
//alert(curId);
vetDrugsId = parseInt(curId);
if (vetDrugsId > 0) {
myDB.transaction(function (transaction) {
transaction.executeSql('SELECT * FROM vetDrugs where Id=?', [vetDrugsId], function (tx, results) {
var len = results.rows.length, i;
if (len > 0) {
$("#title").val(results.rows.item(0).title);
$("#desc").val(results.rows.item(0).desc);
$("#conc").val(results.rows.item(0).conc);
$("#dose").val(results.rows.item(0).dose);
$("#minimum").val(results.rows.item(0).minimum);
$("#maximum").val(results.rows.item(0).maximum);
$('#title,#desc,#conc,#dose,#minimum,#maximum').addClass('error-border');
}
else {
$('#title,#desc,#conc,#dose,#minimum,#maximum').removeClass('error-border');
ClearControl();
}
}, null);
});
}
});
// Cancel the current Operation.
$(".btnCancel").on('click touchstart',function () {
ClearControl();
});
// Clear Control
function ClearControl() {
vetDrugsId = 0;
$("#title").val('');$("#desc").val(''); $("#conc").val(''); $("#dose").val('');
$("#minimum").val(''); $("#maximum").val('');
$('#title,#desc,#conc,#dose,#minimum,#maximum').removeClass('error-border');
}
//Delete Selected Registration data from SQLite Database.
$(document).on('click touchstart', '.delete', function () {
if (confirm("Do you want to delete Drug?")) {
var delString = this.id;
var splitId = delString.split("_");
var curId = splitId[1];
//alert(curId);
id = parseInt(curId);
//var ID = this.id;
//var id = $(this).attr('data-id');
myDB.transaction(function (transaction) {
transaction.executeSql("DELETE FROM vetDrugs where Id=?", [id],
//Success
function (tx, result) {
alert('Deleted successfully');
ClearControl();
RefreshDrugs();
},
//Error
function (error) { alert('Data not deleted.'); });
});
}
});
$(document).on('click touchstart','#DropTable',function () {
if (confirm("Are you sure you want to delete everything?")) {
myDB.transaction(function(transaction) {
//var executeQuery = "DROP TABLE IF EXISTS myDrugs";
//transaction.executeSql(executeQuery, [],
transaction.executeSql("DELETE FROM vetDrugs", [],
function(tx, result) {alert('Data deleted successfully.');
RefreshDrugs();
},
function(error){alert('Error occurred while deleting the table.');}
);
});
}
});