2011-06-08 24 views

回答

24

AFAIK的唯一方法是去引用它们。假设你有2个哈希值,如:{foo: 'bar', baz: 'qux'}

你最好分开存放,然后创建一个SET引用他们都:

HMSET myarr:0 foo bar baz qux 
SADD myarr myarr:0 
HMSET myarr:1 foo bar baz qux 
SADD myarr myarr:1 

然后你就可以通过查询集中检索他们都:SMEMBERS myarr,然后调用HGETALL <key>上所有返回键重建你的原始哈希数组。

我希望这是有道理的。如果你发现更聪明的方式,我会很乐意听到它。

2

如果您使用支持json转换的语言,您可以将您的散列转换为json并将其附加到列表中。您可以在Ruby中执行以下操作:

require 'rubygems' 
require 'redis' 
require 'json' 
require 'pp' 

redis = Redis.new(:host => '127.0.0.1', :port => 6379) 

h1 = { :k1 => 'v1', :k2 => 'v2' } 
redis.rpush('arr', h1.to_json) 

h2 = { :k3 => 'v3', :k4 => 'v4' } 
redis.rpush('arr', h2.to_json) 

hashes = redis.lrange('arr', 0, -1) 
hashes.map! { |x| JSON.parse(x) } 
pp hashes 
+0

这就是实现它的方法! – radtek 2018-03-09 22:05:29