【Redis】redis基本数据结构之Set

简介:

Set类似于Java中的HashSet,实际上是一个比较特殊的Map,所有的value都为null。Set结构和Java中一样,有自动去重的功能,在一些需要去重的场景下可以使用。

操作:

添加元素:sadd setName value

【Redis】redis基本数据结构之Set

移除元素:srem setName value

【Redis】redis基本数据结构之Set

查看set中所有元素 smember setName:

【Redis】redis基本数据结构之Set

 

随机返回删除的元素:spop setName [count] // count为弹出的元素的个数

【Redis】redis基本数据结构之Set

加上个数:

【Redis】redis基本数据结构之Set

取后续集合中没有,但第一个集合中存在的元素:sdiff set1Name set2Name .....:

 【Redis】redis基本数据结构之Set

取后续集合中没有,但第一个集合中存在的元素,并放入到指定的集合中:sdiffstore dstSet set1Name set2Name set3Name ....:

【Redis】redis基本数据结构之Set

 

取交集,sinter set1Name set2Name ...

【Redis】redis基本数据结构之Set

取交集,结果放入一个指定的集合中:sinterstore dstSet set1Name set2Name ...

 【Redis】redis基本数据结构之Set

取并集,sunion payList promotionList

【Redis】redis基本数据结构之Set

 取并集,结果放入一个指定的集合中:sunionstore dstSet set1Name set2Name ...

【Redis】redis基本数据结构之Set

将一个集合中的元素移动到另外一个集合中:smove srcSet dstSet value:

【Redis】redis基本数据结构之Set

获取集合的大小,scard setName:

【Redis】redis基本数据结构之Set

判断元素是否是该集合中的,sismember setName value:

【Redis】redis基本数据结构之Set

 

下面编写一段Go代码来操作Set结构:

package main

import (
	"github.com/garyburd/redigo/redis"
	"fmt"
)

func main(){
	// 连接redis
	conn,err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Errorf("connection redis failed. error info: ", err)
		return
	}

	_,err = conn.Do("sadd", "payList", "zhangfei", "machao", "liubei", "guanyu")
	if err != nil {
		fmt.Errorf("sadd operation is failed. error info: ", err)
		return
	}

	_, err = conn.Do("srem", "payList", "zhangfei")
	if err != nil {
		fmt.Errorf("srem operation is failed. error info: ", err)
		return
	}

	name, err1:= redis.String(conn.Do("spop", "payList"))
	if err1 != nil {
		fmt.Errorf("spop operation is failed. error info: ", err1)
		return
	}
	fmt.Println("the spop get value: ", name)


	defer conn.Close()
}

  

运行效果:

【Redis】redis基本数据结构之Set

 

上一篇:基于redis有序集合,实现简单的延时任务


下一篇:如何利用YouTube学习编程!视频学习的圣地,墙裂推荐!