我的sqlite-datase有一个奇怪的问题。我可以插入并显示我的数据,但我无法删除它们(特别是当我执行“等于”查询时)。
这是我的代码:
<body>
<div id="results">
Results:
</div>
<button onclick="insert_id(); return false;">Insert</button>
<button onclick="show_id(); return false;">Show</button>
<button onclick="delete_id(); return false;">Delete</button>
<script>
var db = openDatabase("testdb", "1.0", "testdb favourites", 2*1024*1024);
function insert_id(){
db.transaction(
function(t){ // This is the callback with "t" as the transaction object
t.executeSql("CREATE TABLE IF NOT EXISTS favourites (id TEXT PRIMARY KEY)");
}
);
var rec_id = "40";
db.transaction(
function(t){
t.executeSql("INSERT INTO favourites VALUES (?)", [rec_id]);
}
);
}
function show_id(){
var list = document.getElementById("results");
var rec_id = 0;
db.transaction(
function(t){
t.executeSql("SELECT id AS rec_id FROM favourites WHERE id > ?" ,[rec_id], function(t,r){
for (var i=0; i < r.rows.length; i++){
rec_id = r.rows.item(i).rec_id;
list.innerHTML +="<li>"+rec_id+"</li>";
}
},
function(t,e){alert("Fehler: " + e.message + "\n\nBitte melde dich bei bauchalarm@outlook.com wenn der Fehler öfters auftritt!");})
}
);
}
function delete_id(){
var rec_id = 40;
db.transaction(
function(t){
t.executeSql("DELETE FROM favourites WHERE id = ?", [rec_id]);
}
);
}
</script>
</body>
如果我查询WHERE id < 40
所有低于40的数据(并且ID为40)将被删除...但当我查询WHERE id = 40
时没有任何反应......
答案 0 :(得分:0)
我认为问题是你的ID是TEXT而不是INT。
尝试将创建表更改为
CREATE TABLE IF NOT EXISTS favourites (id INT PRIMARY KEY);