# 尊敬する Redis が注文したコレクション実装のランキング リストです。困っている友人の役に立てば幸いです。
まえがきインターネットアプリケーションにおいて、ほぼ必須の要素であるランキングは、人間の比較欲求を刺激するものです。売上ランキングや店舗評判ランキングなどのランキングを実装する方法. クイックソートアルゴリズムを使用して、特定の重みでソートするComparatorインターフェイスを実装できます. 現在、多くの企業がNoSQLデータベースであるredisを使用してランキング機能を実装していますredisをベースにランキングリストを実装
これからやるべきことは企業のランキングです ユーザーによる企業の検索数をランキング基準としてランキングを作成します上位10社
1 .redis関連知識
ランキング機能の実装に関わるredisのデータ構造はソートセット(順序セット)ですソートセットについてset は Set であることはわかっていますが、set の特徴の 1 つは、重複する要素がないことです。ソート セットには、重複する要素がないことに加えて、順序性という特徴もあります。 データ構造の構成: key: ソートセットの一意の識別子###String(set key),double(权重),String(value)
ZADD "KEY" SCORE "VALUE" [ SCORE "VALUE"]
MyRedis:0>ZADD test 1 "one""1"MyRedis:0>zadd test 4 "four" 5 "five""2"
ZCARD "key"
MyRedis:0>ZCARD test"5"
ZSCORE "KEY" "VALUE"
MyRedis:0>ZSCORE "test" "one""2"
ZINCRBY "key" score "value"
MyRedis:0>ZSCORE "test" "one""2"MyRedis:0>ZINCRBY "test" 1 "one""3"MyRedis:0>ZSCORE "test" "one" "3"
ZRANGE "key" 开始下标 结束下标
MyRedis:0>ZRANGE "test" 0 1 1) "two" 2) "one"
<dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-data-redis</artifactid> </dependency>
//=============================== sort set ================================= /** * 添加指定元素到有序集合中 * @param key * @param score * @param value * @return */ public boolean sortSetAdd(String key,double score,String value){ try{ return redisTemplate.opsForZSet().add(key,value,score); }catch (Exception e){ e.printStackTrace(); return false; } } /** * 有序集合中对指定成员的分数加上增量 increment * @param key * @param value * @param i * @return */ public double sortSetZincrby(String key,String value,double i){ try { //返回新增元素后的分数 return redisTemplate.opsForZSet().incrementScore(key, value, i); }catch(Exception e){ e.printStackTrace(); return -1; } } /** * 获得有序集合指定范围元素 (从大到小) * @param key * @param start * @param end * @return */ public Set sortSetRange(String key,int start,int end){ try { return redisTemplate.opsForZSet().reverseRange(key, start, end); }catch (Exception e){ e.printStackTrace(); return null; } }
/** * 根据公司名找到指定公司 * @param companyName * @return */ @Override public AjaxResult selectCompanyName(String companyName) { Set<object> set = redisUtils.sGet("company"); for(Object i : set){ String json = JSONObject.toJSONString(i); JSONObject jsonObject = JSONObject.parseObject(json); if(jsonObject.getString("companyName").equals(companyName)){ //搜索次数 + 1 redisUtils.sortSetZincrby("companyRank",companyName,1); log.info("直接缓存中返回"); return new AjaxResult().ok(jsonObject); } } log.error("缓存中没有,查数据库"); TbCommpanyExample tbCommpanyExample = new TbCommpanyExample(); tbCommpanyExample.createCriteria().andCompanyNameEqualTo(companyName); List<tbcommpany> list = tbCommpanyMapper.selectByExample(tbCommpanyExample); if(list.size() != 0){ //放入缓存中 redisUtils.sSet("company",list.get(0)); //数据库中存在 //搜索次数 + 1 redisUtils.sortSetZincrby("companyRank",companyName,1); log.info("sql"); return new AjaxResult().ok(list.get(0)); }else{ return new AjaxResult().error("没有找到该公司:"+companyName); } }</tbcommpany></object>
/** * 获得公司排行榜(前十) * @return */ @Override public AjaxResult getCompanyRank() { Set set = redisUtils.sortSetRange("companyRank",0,9); if(set.size() == 0){ return new AjaxResult().error("公司排行榜为空"); } return new AjaxResult().ok(set); }
带时间戳的分数 = 实际分数*10000000000 + (9999999999 – timestamp)
以上がRedis の順序付けされたコレクションに基づいたランキング リストを実装する Java についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。