redis是k-v,set前要序列化

本文通过一个实验展示了如何处理K为字符串,V为字符串数组的情况,当V在Redis中已存在时,如何追加数据。重点讨论了在将V存储到Redis前进行序列化的必要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面展示一个实验,把K是string,V是[]string,存入redis中
如果V在redis中存在,则要追加数据

func saveUserDisLike(userDisLikeMap map[string][]string, redisName string) {
	countScope := countstat.GetCountGlobal().NewCountScope("saveUserDisLike")
	countScope.SetErr()
	defer countScope.End()

	rdsClient, ok := client.Clientmanager.GetRedisClient(redisName)
	if !ok {
		log.Errorf("[%s] get redis client err, key:%s", redisName)
		return
	}

	for k, v := range userDisLikeMap {
		//查看k在redis中是否存在
		data, err := rdsClient.Get(k)
		if err != nil || data == nil {//data==nil表示这个k在redis中不存在
			log.Warnf("get nil or rds get err: %v", err)
			continue
		}

		//走到这里,表示redis中存在k,则要取出K的v,追加数据
		//这里要注意,从redis取出v后,一定要反序列化到它真实的结构上
		resultList := make([]string, 0)
		if err := json.Unmarshal(data.([]byte), &resultList); err != nil {
			log.Warnf("unmarshal err: %v", err)
			continue
		}

		//追加数据
		v = append(v, resultList...)
		if len(v) > DISLIKE_MAX_NUM {
			v = v[:DISLIKE_MAX_NUM]
		}
		userDisLikeMap[k] = v
	}

	saveDatas := make([]interface{}, 0, 2*len(userDisLikeMap))
	for key, disLikeReason := range userDisLikeMap {
		//为了执行Mset,一个key一个value放好
		//先放key
		saveDatas = append(saveDatas, key) //key

		//对value进行序列化
		value, err := json.Marshal(disLikeReason)
		if err != nil || value == nil {
			log.Warnf("Marshal err: %v", err)
			continue
		}

		//再放value
		saveDatas = append(saveDatas, value) //value
	}

	//MSet批量更新
	if e := rdsClient.MSet(saveDatas); e != nil {
		log.Warnf("mset[%v] error %s", saveDatas, e.Error())
	}

	countScope.SetOk()
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值