go随聊-Redis实战 操作Set

go-redis/redis

地址:https://github.com/go-redis/redis

Supports:

  • Redis 3 commands except QUIT, MONITOR, SLOWLOG and SYNC.
  • Automatic connection pooling with circuit breaker support.
  • Pub/Sub.
  • Transactions.
  • Pipeline and TxPipeline.
  • Scripting.
  • Timeouts.
  • Redis Sentinel.
  • Redis Cluster.
  • Cluster of Redis Servers without using cluster mode and Redis Sentinel.
  • Ring.
  • Instrumentation.
  • Cache friendly.
  • Rate limiting.
  • Distributed Locks.

安装

go get -u github.com/go-redis/redis

创建客户端

import "github.com/go-redis/redis"

func RedisInit(addr string) (*redis.Client,error) {
	redisdb := redis.NewClient(&redis.Options{
		Addr:     	addr,
		Password: 	"",
		DB:       	0,
		PoolSize:	10,
	})
	_,err := redisdb.Ping().Result()
	if err!=nil {
		return nil,err
	}else{
		return redisdb,nil
	}
}
redisdb,err:=RedisInit("192.168.10.25:6379")

RedisInit函数正确返回*redis.Client(redisdb),后续所有操作都使用这个redisdb

Set操作

sadd(key, member)

将一个或多个 member 元素加入到集合 key 当中,已经存在于集合的 member 元素将被忽略。

假如 key 不存在,则创建一个只包含 member 元素作成员的集合。

当 key 不是集合类型时,返回一个错误。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SAdd("k1","a","b","c","d").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}
-------------------------------------------------------------
4    //返回插入成功的数目

srem(key, member)

移除集合 key 中的一个或多个 member 元素,不存在的 member 元素会被忽略。

当 key 不是集合类型,返回一个错误。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SRem("k1","c","d").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}

spop(key) :随机返回并删除名称为key的set中一个元素。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SPop("k1").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}

smove(srckey, dstkey, member)

将 member 元素从 source 集合移动到 destination 集合。

SMOVE 是原子性操作。

如果 source 集合不存在或不包含指定的 member 元素,则 SMOVE 命令不执行任何操作,仅返回 0 。否则, member 元素从 source 集合中被移除,并添加到 destination 集合中去。

当 destination 集合已经包含 member 元素时, SMOVE 命令只是简单地将 source 集合中的 member 元素删除。

当 source 或 destination 不是集合类型时,返回一个错误。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SMove("k1","k2","1").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}
------------------------------------------------------
k1原来是1,2,3
k2原来是4,5,6
执行后:
k1是2,3
k2是1,4,5,6

scard(key) :返回集合 key 的基数(集合中元素的数量)。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SCard("k1").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}

sismember(key, member) :member是否是名称为key的set的元素。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SIsMember("k1",2).Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}
-----------------------------------------------------
true
判断2是不是k1的元素,返回true

sinter(key1, key2,…key N) :求交集。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SInter("k1","k2").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}
----------------------------------------------------
k1是1,2,3,6
k2是1,4,5,6
执行结果为:
1,6

sunion(key1, (keys)) :求并集。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SUnion("k1","k2").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}
----------------------------------------------------
k1是1,2,3,6
k2是1,4,5,6
执行结果为:
1,2,3,4,5,6

sdiff(key1, (keys)) :求差集。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SDiff("k1","k2").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}
----------------------------------------------------
k1是1,2,3,6
k2是1,4,5,6
执行结果为:
2,3

smembers(key) :返回名称为key的set的所有元素。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SMembers("k1").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}

srandmember(key) :随机返回名称为key的set的一个元素。

func SetTest(redisdb *redis.Client) {
	ret,err:=redisdb.SRandMember("k1").Result()
	if err!=nil {
		fmt.Println(err)
		return
	}
	fmt.Println(ret)
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值