作者:_快樂Smile_903 | 来源:互联网 | 2023-05-19 19:24
在npm文档中,只有可见的预处理语句用于插入.这些准备好的语句是否适用于选择,更新和删除?
我试过select,没有一个.each
函数可以回调行.任何人都可以这样做或有资源链接,因为我可以肯定无法找到任何.
1> c.hill..:
根据node-sqlite3 API文档,您可以通过几种不同的方式在SQL查询中使用参数:
// Directly in the function arguments.
db.run("UPDATE tbl SET name = ? WHERE id = ?", "bar", 2);
// As an array.
db.run("UPDATE tbl SET name = ? WHERE id = ?", [ "bar", 2 ]);
// As an object with named parameters.
db.run("UPDATE tbl SET name = $name WHERE id = $id", {
$id: 2,
$name: "bar"
});
Izc正在询问使用SELECT的准备好的语句,这显示了一种解决方法,但没有回答问题。
2> Bernardo Ram..:
是的,支持准备好的声明.
使用node-sqlite3:
var sqlite3 = require('sqlite3').verbose();
var db = new sqlite3.Database('data.db');
db.serialize(function() {
var stmt = db.prepare("INSERT INTO users VALUES (?,?)");
for (var i = 0; i <10; i++) {
stmt.run("user " + i, "email " + i);
}
stmt.finalize();
stmt = db.prepare("SELECT * FROM users WHERE id=?");
stmt.each(userId, function(err, row) {
console.log(row.name, row.email);
}, function(err, count) {
stmt.finalize();
});
});
使用better-sqlite3:
var Database = require('better-sqlite3');
var db = new Database('foobar.db', options);
var stmt = db.prepare("INSERT INTO users VALUES (?,?)");
for (var i = 0; i <10; i++) {
stmt.run("user " + i, "email " + i);
}
var stmt = db.prepare('SELECT * FROM users WHERE id=?');
var row = stmt.get(userId);
console.log(row.name, row.email);