如何使用排序集从Redis获取多个键的值?
zadd Users 0 David zadd Users 5 John zadd Users 15 Linda zrevrange Users 0 -1 withscores
这将有两个用户。
如何在一个查询中检索具有键“ David”和“ Linda”的用户?
无需在Redis中引入新命令的方法有多种。
例如,您可以使用感兴趣的名称填充临时集,然后计算该临时集与zset之间的交集:
multi sadd tmp David Linda ... and more ... zinterstore res 2 tmp Users weights 0 1 zrange res 0 -1 withscores del tmp res exec
使用流水线操作,只会产生一次往返,并且您可以在tmp中填充任意数量的输入参数。
使用Redis 2.6,您还可以将这些行包装到服务器端Lua脚本中,以最终获得一个接受输入列表并返回所需结果的命令:
eval "redis.call( 'sadd', 'tmp', unpack(KEYS) ); redis.call( 'zinterstore', 'res', 2, 'tmp', 'Users', 'weights', 0, 1 ); local res = redis.call( 'zrange', 'res', 0, -1, 'withscores' ); redis.call( 'del', 'res', 'tmp' ) ; return res " 2 David Linda
如果可以使用脚本轻松实现,则可以放心地假设不会向Redis添加任何新命令。