执行诺言后代码不会中断

时间:2018-08-14 18:46:16

标签: javascript mysql node.js lambda promise

我目前在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;

1 个答案:

答案 0 :(得分:2)

由于您处于节点流程中,因此可以先使用process.exitCode = 1然后再使用process.exit()process.exit(1)退出。

Here is the documentation

That however is not the best practice。最简单的方法是抛出一个错误:

throw "Exit!"或您想要捕获并重新抛出以退出的某些错误(在具有catch语句的情况下)