javascript - 同样的 promise 给出两个不同的结果

标签 javascript promise bluebird knex.js

大家早上好。

我一直在研究一个给我带来问题的函数。

.then(function (values2) {
  function generateReports () {

    return Promise.all([
        Reports.InterCompaniesUsa                   .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.InterCompaniesCanada                .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Design                              .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Production                          .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),

        Reports.MonthlySalesByCustomers             .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Cashing                             .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Income                              .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.AgedTrialBalance                    .generate(periodToClose.date_start, periodToClose.date_end, {save: true})
    ])
  }

  function generateAllAccountStatement () {
    db.select('invoices.customer_id_customer')
      .distinct('invoices.customer_id_customer')
      .from('invoices')
      .where({
        'invoices.invoice_status': 'INVOICED'
      })
      .andWhere(function () {
        this.where('invoices.invoice_date', '<=', periodToClose.date_end)
          .andWhere('invoices.invoice_date', '>=', periodToClose.date_start)
      })
      .orWhere(function () {
        this.where('invoices.invoice_date', '<=', periodToClose.date_start)
          .andWhere('invoices.balance', '<>', 0)
      })
      .then(function (arrOfCustomersWithInvoicesThisMonthOrWithPostponeBalance) {
        arrOfCustomersWithInvoicesThisMonthOrWithPostponeBalance.forEach(function (oneCustomer) {
          Reports.AccountStatement.generate(periodToClose.date_end, oneCustomer.customer_id_customer, {save: true});
        })
      })
      .catch(function (err) {
        console.error(err)
      })
  }

  return Promise.all([generateReports(), generateAllAccountStatement()])
})
.then(function (allIsDoneYes) {
  return res.json(allIsDoneYes);
})
.catch(function (err) {
  console.error(err);
  return res.status(500).send(err);
})

我的问题是:函数 generateReports 没有解析。我试图将其中的每个 promise 都隔离开来,它们都很好。当我用下面的这段代码替换该函数时,它起作用了,我想知道为什么(因为它们对我来说看起来几乎一样)。

function generateReports () {
    Promise.all([
        Reports.InterCompaniesUsa                   .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.InterCompaniesCanada                .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Design                              .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Production                          .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),

        Reports.MonthlySalesByCustomers             .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Cashing                             .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.Income                              .generate(periodToClose.date_start, periodToClose.date_end, {save: true}),
        Reports.AgedTrialBalance                    .generate(periodToClose.date_start, periodToClose.date_end, {save: true})
    ])
    .then(result => {
        return result;
    })
    .catch(err => {
        console.error(err);
    })
}

最佳答案

可能是当你运行这么多并行的时候

Reports.*.generate(periodToClose.date_start, periodToClose.date_end, {save: true}),

并行查询,如果生成的代码有一些错误或奇怪的依赖关系,它们可能会填满您的池并阻塞整个应用程序。

尝试将 DEBUG=knex:* 环境变量添加到您的 shell 并运行您的报告生成代码:

await generateReports();

看看你是否能发现数据库连接有什么奇怪的地方,或者看看解决这个 promise 的地方。

您也可以首先尝试制作更小的 generateReports 实现,它只生成一个报告,然后向其中添加更多报告,直到您找到 promise 不再解决的组合。

关于javascript - 同样的 promise 给出两个不同的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53176080/

相关文章:

javascript - NodeJs/Bluebird - 不断收到未处理的拒绝错误

javascript - 如何在页面转换时生成 gif 动画?

javascript - 如何在 if 语句返回 false 的情况下中止 jquery 函数

javascript - Promise 通过 for 循环提前返回

javascript - 你如何使用 JS Promises 在 API 返回值时继续从 API 请求?

node.js - 等待所有查询完成并同时异步填充

javascript - Promises 和通用的 .catch() 语句

javascript - CKEditor 上下文菜单在模态中的位置不正确

javascript - 动态选择框和动态 DIV,设置元素而不是删除/附加

javascript - 在 Promise 中传递多个参数