[redis数据结构] 之 set集合

    在redis中,集合类型有两种,一种是无序、不重复的(set),另一种是有序的(zset);本文讲述无序集合的语法使用规则。理解redis中的集合类型,可以类比于数学中的集合,集合存在三种关系:交集、并集、差集,其中差集的概念有一点的出入,详细见语法使用描述。

    1、添加元素

语法:sadd [set集合] [元素]
范例:sadd set1 one
      sadd set1 one
阐述:创建set1结合,并添加one元素到集合中,如果set1已经存在,那么仅仅添加元素过程;第二次添加one元素不成功,因为集合是不重复的。

    2、删除元素

# 删除元素有两种方式:一种是删除指定元素;另一种是随机删除
# 删除指定元素
语法:srem [set集合] [元素]
范例:srem set1 one  # 删除set1中的one元素

# 随机删除一个元素
语法:spop [set集合] [元素]
范例:spop set1 # 随机删除set1集合中的一个元素,并返回删除的元素

    3、交集

语法1:sinter [set1] [set2]...[setn]
范例:sinter set1 set2 set3 
阐述:获取三个集合中的共同元素

# 语法1可以获取集合之间的交集,但是交集元素集合是暂时性质的,如果想将交集结果存储到指定的# 集合中可采取语法2.
语法2:sinterstore [存储set] [set1] [set2] ... [setn]
范例:sinterstore set4 set1 set2 set3
阐述:将set1,set2,set3的交集结果存储到set4中

    4、并集

# 与交集一样分为两种语法规则。
语法1:sunion [set1] [set2]...[setn]
语法2: sunionstore [set1] [set2]...[setn]

范例:sunion set1 set2 set3
      sunuinstore set1 set2 set3

    5、差集

# 与交集一样分为两种语法规则。
语法1:sdiff[set1] [set2]...[setn]
语法2: sdiffstore [set1] [set2]...[setn]

范例:sdiff set1 set2 set3
      sdiffstore set1 set2 
阐述:在数学中的差集是两者都相同的元素的集合,但是前者集合与后者集合不同的元素列表。例如:set1={1,2,3},set2={2,3,4},set3={3,4,5},那么sdiff set1 set2 set3的结果为{1},也就是set1与set2、set3集合不同的元素列表。

    6、遍历集合

语法:smembers [set集合]
范例:smembers set1 # 遍历set1集合,无序输出

    7、移动元素

语法:smove [set1] [set2] [元素]
范例:smove set1 set2 one # 将set1中的one元素删除,并添加到set2中

    8、获取集合大小

语法:scard [集合]
范例:scard set1 # 获取set1集合大小

    9、随机获取元素

语法:srandmember [集合]
范例:srandmember set1 # 随机获取set1集合中的一个元素,但不删除

    10、判断是否包含某个元素

语法:sismember [set集合] [元素]
范例:sisimember set1 one # 判断one是否是set1中的元素,是则返回1,否则返回0


你可能感兴趣的:(redis,set,数据类型)