问题描述
我正在尝试使用SQLite3为不和谐的bot(在node.js上)创建一个小型数据库,并且我想创建一个函数,以提供的值更新数据库(此部分有效)或返回一个值数据库。
我的问题在这里,返回值始终是不确定的...
我已经了解到SQLite3命令是异步的,因此所有功能都变为异步,但是如何确保返回的值不再是未定义的?
这是我的代码:
const sqlite3 = require('sqlite3');
const dbname = 'dbStocks';
module.exports = function gestionBDD(update,nomArticle,quantitéArticle) {
console.log('1 ' + quantitéArticle);
let db = new sqlite3.Database(dbname,(err) => {
if (err) throw err;
console.log('Démarrage de ' + dbname);
});
db.serialize(() => {
nomArticle = '"' + nomArticle + '"';
if (update) {
//Si update est true : maj des quantités via le tableau articles
db.run(
`UPDATE stocks
SET Quantité = (` +
quantitéArticle +
`)
WHERE Article = (` +
nomArticle +
`)`
);
} else if (!update) {
db.each(
`SELECT Quantité FROM stocks WHERE Article = (` + nomArticle + `)`,(err,data) => {
console.log('2 ' + data.Quantité);
return data.Quantité;
}
);
}
console.log('4 ' + quantitéArticle);
db.close((err) => {
if (err) throw err;
console.log('Arrêt de ' + dbname);
});
});
};
我得到这个结果:
1 undefined
4 undefined
3 undefined
Démarrage de dbStocks
2 500
Arrêt de dbStocks
(3 undefined
是我的console.log()
中调用函数index.js
的{{1}}中的gestionBDD
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)