php hyperf 读取redis,存储到数据库

9 篇文章 0 订阅

背景说明
小白:伟哥,java中的set是无序的,Redis中可以带顺序吗?

伟哥:可以, 不过不叫set了,叫zset。

概述
SortedSet又叫zset,它是Redis提供的特殊数据类型,是一种特殊的set类型,继承了set不可重复的特点,并在set基础上为每个值添加一个分数,用来实现值的有序排列。
在这里插入图片描述

redis中排行榜中的数据
在这里插入图片描述

在这里插入图片描述

    public function execute(string $date)
    {
        $query = ChannelConfig::query();
        $query->where('module_name', 'rank_reward');
        $rewardData = $query->first();
        $rewards = [];
        if( $rewardData ){
            $rewardContents = $rewardData->content;
            foreach ($rewardContents as $key => $value) {
                if( !key_exists($value["game_type"], $rewards) ){
                    $rewards[$value["game_type"]] = [];
                }
                $rewards[$value["game_type"]][$value["rank"]] = $value["reward"];
            }
        }
        echo json_encode($rewards);

        $redisFactory = ApplicationContext::getContainer()->get(RedisFactory::class);
        $redis = $redisFactory->get('rank');

        $day = substr($date,5,2).substr($date,8,2);
        $keys = $redis->keys("RANK:*:$day:0-0");
        foreach ($keys as $key => $value) {
            // echo "key = $value \n";
            $kuCuns = $redis->ZREVRANGE($value, 0, 29, true);
            // echo "data = ".json_encode($kuCuns)."\n";
            $gameType = explode(":",$value)[1];
            $count = count($kuCuns);
            $index = 1;
            foreach ($kuCuns as $keyItem => $valueItem) {
                $mode = new RankLog();
                $mode->date = $date;
                $mode->index = $index;
                $mode->gameType = $gameType;
                $mode->userId = $keyItem;
                $mode->score = $valueItem;
                $mode->reward = key_exists($gameType, $rewards) ? $rewards[$gameType][$index] : "";
                $mode->save();
                $index++;
            }
        }
    }

转自:https://zhuanlan.zhihu.com/p/629389490

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

游鱼_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值