node.js redis promisify with.multi或.batch

k5ifujac  于 2021-06-10  发布在  Redis
关注(0)|答案(0)|浏览(385)

使用npm模块redis,我对单个命令使用utils promisify没有问题。

const { promisify } = require("util");
const redis = require("redis");
const client = redis.createClient();

const hmgetAsync = promisify(client.hmget).bind(client),

现在我想能够使用.multi和.batch方法。
下面是我的一个助手函数的示例,它使用.batch而不使用promisify和non命令的promisify版本。

const getData = async (ids) => {
    const batch = client.batch();

    ids.forEach(id => {
        batch.hgetall(id)
    });

    return new Promise((resolve, reject) => {
        batch.exec((err, replies) => {
            if (err) {
                reject(err);
            }

            const data = replies
                // missing keys require filtering
                .filter(it => !!it)
                .map(dataPoint => _toDataPoint(dataPoint));

            resolve(data);
        })
    })
};

工作没有问题,但我很好奇是否有可能使用promisify与.multi或.batch
非常感谢,

暂无答案!

目前还没有任何答案,快来回答吧!

相关问题