Redis之sets类型及操作

来源:互联网 发布:音乐版权 知乎 编辑:程序博客网 时间:2024/06/14 03:26

SETS

set是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作,操作中key理解为集合的名字。 set的是通过hash table实现的,所以添加、删除和查找的复杂度都是O(1)。hash table会随着添加或者删除自动的调整大小。需要注意的是调整hash table大小时候需要同步(获取写锁)会阻塞其他读写操作,可能不久后就会改用跳表(skip list)来实现,跳表已经在sorted set中使用了。关于set集合类型除了基本的添加删除操作,其他有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现sns中的好友推荐和blog的tag功能


sadd
向名称为key的set中添加元素
sadd key member [member …]

srem
删除名称为key的set中的元素member
srem key member [member …]

spop
随机返回并删除名称为key的set中的元素
spop key count

sdiff
返回所有给定key与第一个key的差集
sdiff key1 key2 key3 ….
返回的是key1中key2和key3不包含的元素

sdiffstore
返回所有给定key与第一个key的差集,并将结果存为另一个key
sdiffstore destination key [key …]

sinter
返回所有给定key的交集
sinter key [key …]

sinterstore
返回所有给定key的交集,并将结果存为另一个key
sinterstore destination key [key …]

sunion
返回所有给定key的并集
sunion key [key …]

sunionstore
返回所有给定key的并集,并将结果存为另一个key
sunionstore destination key [key ..]

smove
从第一个key对应的set中移除member并添加到第二个对应set中
smove source destination member

scard
返回名称为key的set的元素个数
scard key

sismember
测试member是否是名称为key的set的元素
sismember key member

srandmember
随机返回名称为key的set的一个元素,但是不删除元素
srandmember key [count]

0 0
原创粉丝点击