首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >承诺执行后未中断的代码

承诺执行后未中断的代码
EN

Stack Overflow用户
提问于 2018-08-15 02:46:16
回答 1查看 60关注 0票数 1

我目前在Node.js中有一个问题,我使用promise-mysql和bluebird包调用mysql数据库。我遵循了网页上的教程,它似乎起作用了。我总是以超时错误结束,因为一旦查询了数据库,进程就不会中断(如果这是正确的术语),并且我必须使用ctrl +c终止进程,或者在Alexa上测试时,当技能人员回复存在问题时。检索到查询的值后,有没有办法结束promise和db连接?下面是代码的一个例子。

index.js

代码语言:javascript
复制
'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

代码语言:javascript
复制
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

代码语言:javascript
复制
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;
EN

回答 1

Stack Overflow用户

发布于 2018-08-15 04:06:28

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

Here is the documentation

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

throw "Exit!"或一些您希望捕获并重新抛出以退出的错误(在使用catch语句的情况下)

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51847983

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档