我目前在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;
发布于 2018-08-15 04:06:28
由于您处于节点进程中,因此可以先使用process.exitCode = 1
退出,然后使用process.exit()
或process.exit(1)
退出。
That however is not the best practice。最简单的方法就是抛出一个错误:
throw "Exit!"
或一些您希望捕获并重新抛出以退出的错误(在使用catch语句的情况下)
https://stackoverflow.com/questions/51847983
复制相似问题