redis客户端和节点js - hgetall方法失败,结果为空

时间:2016-09-12 20:16:04

标签: javascript node.js redis redis-cli redisclient

这对我来说是第一天的redis cilent和node js。

我试图通过node.js中的redis-cli复制这个命令:

127.0.0.1:6379> HGETALL widgets:9145090003_00:00_00:00
1) "id"
2) "33305"
3) "loc"
4) "jamaica"
5) "days"
6) ""

这里是nodejs代码:

client.hgetall("widgets:9145090003_00:00_00:00", function (err, replies) {
        console.log(err);
        replies.forEach(function (reply,i) {
                console.log('  ' + i + ':' + reply);
        }); 
});

它返回null,然后在尝试执行foreach时失败。

我也试过了:

 client.hgetall("widgets", function (err, replies) {
            console.log(err);
            replies.forEach(function (reply,i) {
                    console.log('  ' + i + ':' + reply);
            }); 
    });

但我得到了同样的结果。

不确定我做错了什么。

编辑1

我试过这段代码:

 17 console.log("attempting to do hgetall..");
 18 client.hgetall("widgets:9145090003_00:00_00:00", function (err, replies) {
 19         //for (let k in replies) console.log(' ${k}:${replies[k]}');
 20         console.log(replies.id);
 21 });

以下是结果:

/var/www/html/node/test/models/Widgets.js:20
    console.log(replies.id);
                       ^

TypeError: Cannot read property 'id' of null

然而,在CLI中我可以这样做:

127.0.0.1:6379> HGET widgets:9145090003_00:00_00:00 id
"33305"
127.0.0.1:6379> HGETALL widgets:9145090003_00:00_00:00
1) "id"
2) "33305"
3) "loc"
4) "jamaica"
5) "days"
6) ""
127.0.0.1:6379> 

2 个答案:

答案 0 :(得分:1)

hgetall的回复是Object类型,尝试在代码中添加以下行

console.log(replies.id);

您将在控制台中打印33305。

答案 1 :(得分:0)

我试图复制你正在做的事情。我首先检查您是否正在连接到正确的redis实例。如果你是,问题是forEach函数适用于数组,但这里的回复是一个对象,没有Object.prototype.forEach函数。您必须以不同方式循环响应。如果您已连接到正确的redis实例,我就会以一种应该正常工作的方式重写您的代码。

client.hgetall("widgets:9145090003_00:00_00:00", function (err, replies) {
        console.log(replies);
        for(let k  in replies) {
           console.log(` ${k}:${replies[k]}`);
        }
});