0

我正在阅读这篇文章并根据示例编写了我的代码。

我的代码:

const through = require('through2'); const bluebird = require('bluebird');

function streamToPromise(stream) {
  return new Promise(function(resolve, reject) {
    stream.resume();
    stream.on("end", resolve);
    stream.on("error", reject);
  });
};

module.exports = {
  up: function up() {
    console.log('startstream');
    // Doc is sequelize Model
    const stream = Doc.createReadStream({
      include: [
        {
          repository: AssociatedRepo,
          as: 'on',
          required: false,
        },
      ],
    });

    stream.pipe(through({ objectMode: true }, (doc, enc, cb) => {
      console.log('docid', doc.id);
      return doc.destroy()
        .then(() => cb());
    }));
    return streamToPromise(stream).then((data) => {
      console.log('xxxxxxxxxx', data);
      return null;
    });
  },
};

我尝试使用上述程序读取和删除大约 400 条记录。但从日志中,我发现流承诺 ( streamToPromise(stream)) 已解决,但仍有几条记录。从日志中,我得到:

xxxxxxxxxx undefined
docid 89934915596

如何解决这个问题?谢谢

4

1 回答 1

0

您需要等待 的目标流结束pipe,目前您只等待输入流。利用

const res = stream.pipe(through({objectMode: true}, …));
return streamToPromise(res);
于 2017-12-06T21:08:22.250 回答