我目前在Node.js中有一个问题,即我使用promise-mysql和bluebird包调用mysql数据库。我按照网页上的教程进行操作,似乎可以正常工作。我一直以超时错误结束,因为一旦查询了数据库,该过程就不会中断(如果这是正确的条件),我要么必须使用ctrl + c终止该过程,要么当该技能回复时在Alexa上进行测试有一个问题。一旦检索到查询的值,是否可以终止promise和db连接?下面是代码示例。
index.js
'use strict';
const Alexa = require('alexa-sdk');
const mysql = require('promise-mysql');
const querydb = require('./sqlQuery.js');
const insertdb = require('./sqlInsert.js');
var testSQL = 'SELECT weight, height from users where pin=1100';
var valuesPromise = querydb.getItem(testSQL);
valuesPromise.then((result)=>{
rows = result.height;
row2 = result.weight;
console.log(rows);
console.log (row2);
return true;
}).catch(function(error){
console.log (error);
});
databaseConnection.js
var mysql = require('promise-mysql');
pool = mysql.createPool({
host: "hostURL",
database: "dbName",
user: "dbUser",
password: "dbPassword",
connectionLimit: 1
});
function getSqlConnection() {
return pool.getConnection().disposer(function(connection) {
pool.releaseConnection(connection);
});
}
module.exports = getSqlConnection;
sqlQuery.js
var Promise = require("bluebird");
var getSqlConnection = require('./databaseConnection');
function getItem(sql){
return Promise.using(getSqlConnection(), function(connection) {
return connection.query(sql).then(function(rows) {
return rows[0];
}).catch(function(error) {
return (error);
});
})
};
module.exports.getItem = getItem;
答案 0 :(得分:2)
由于您处于节点流程中,因此可以先使用process.exitCode = 1
然后再使用process.exit()
或process.exit(1)
退出。
That however is not the best practice。最简单的方法是抛出一个错误:
throw "Exit!"
或您想要捕获并重新抛出以退出的某些错误(在具有catch语句的情况下)