目录

1 简单介绍

2 常用命令

3 数据结构


1 简单介绍

        Redis set对外提供的功能与list是一个列表的功能,特殊之处在于set是可以自动去重的,当你需要存储一个列表数据,又不需要出现重复数据时,set是一个很好的选择,并且set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不提供的。

Redis set是string类型的无序集合。它底层其实是一个value为null的hash表,所以添加,删除,查找复杂度都是o(1).

一个算法,随着数据的增加,执行时间的长度,如果是o(1),数据增加,查找数据的时间不变。

2 常用命令

sadd <key> <value1> <value2> 将一个或多个元素加入到集合key中,已经存在的member元素将被忽略

smember<key> 取出该集合的所有值

redis set 查询 redis查看set中的数据_数据库

sismember <key> <value> 判断集合<key> 是否为含有该<value>值,有值则为1,无值则为0 

redis set 查询 redis查看set中的数据_数据结构_02

scard 返回集合中元素的个数

redis set 查询 redis查看set中的数据_database_03

 

srem <key> <value1> <value2> ...删除集合中的某个元素

redis set 查询 redis查看set中的数据_database_04

spop <key> 随机从集合中取出一个值

redis set 查询 redis查看set中的数据_redis_05

srandmember <key> <n> 随机从该集合中取出n个值。不会从集合中删除

redis set 查询 redis查看set中的数据_数据结构_06

 

smove <source> <destination> value将集合中一个值从一个集合移动到另外一个集合

redis set 查询 redis查看set中的数据_数据库_07

sinter <key1> <key2> 返回两个集合的交集元素

sunion <key1> <key2> 返回两个集合的并集元素

sdiff <key1> <key2> 返回两个集合的差集元素(key1中的,不包含key2中的)

redis set 查询 redis查看set中的数据_redis_08

3 数据结构

 Set数据结构是dict字典,字典是用hash表实现的。Java中HashSet的内部实现用的是HashMap,只不过所有的value都指向同一个对象。Redis的Set结构也是一样,它的内部也使用hash结构,所有的value都指向同一个内部值