Redis不同数据类型代码场景实践

string

博客不好的实现

jedis.set("key1", "value1");
jedis.get("key1");
jedis.del("lock_test");
jedis.incr("blog_id_counter");
Long key = jedis.incrBy("key", 1);
jedis.set("lock_test", "value_test", SetParams.setParams().nx());
Long publishBlogResult = jedis.msetnx("article:1:title", "学习Redis",
                "article:1:content", "如何学好redis的使用",
                "article:1:author", "deltaqin",
                "article:1:time", "2020-01-01 00:00:00");
List<String> blog = jedis.mget("article:1:title", "article:1:content",
                "article:1:author", "article:1:time");
String updateBlogResult = jedis.mset("article:1:title", "修改后的学习redis",
                "article:1:content", "修改后的如何学好redis的使用");
jedis.strlen("article:1:content");
jedis.getrange("article:1:content", 0, 5);
jedis.append("operation_log_2020_01_01", "今天的第" + (i + 1) + "条操作日志\n");

hash

hash就是一个hashmap,还自带变量名

jedis.hset("short_url_access_count", shortUrl, "0");
jedis.hset("url_mapping", shortUrl, url);
jedis.hget("short_url_access_count", shortUrl);

博客好

一篇文章的所有属性在一个hash里面,key是一篇文章,field是不同属性,val是不同值


jedis.hexists("article::" + id, "title");
jedis.hmset("article::" + id, blog);  # blog 是 hashmap
Map<String, String> blog = jedis.hgetAll("article::" + id);
jedis.hincrBy("article::" + id, "like_count", 1);

session

SimpleDateFormat dateFormat = new SimpleDateFormat(
    "yyyy-MM-dd HH:mm:ss");

// 设置24小时过期
Calendar calendar = Calendar.getInstance();
calendar.setTime(new Date());
calendar.add(Calendar.HOUR, 24);
Date expireTime = calendar.getTime();

jedis.hset("sessions",
           "session::" + token, String.valueOf(userId));
jedis.hset("sessions::expire_time",
           "session::" + token, dateFormat.format(expireTime));


jedis.hget("sessions", "session::" + token);

// 检测过期
jedis.hget("sessions::expire_time",  "session::" + token);
SimpleDateFormat dateFormat = new SimpleDateFormat(
    "yyyy-MM-dd HH:mm:ss");
Date expireTimeDate = dateFormat.parse(expireTime);

Date now = new Date();

if(now.after(expireTimeDate)) {
    return false;
}

list

博客分页

jedis.hmset("article::" + id, blog);
jedis.lpush("blog_list", String.valueOf(id));

// 分页查询
//  pageNo * pageSize - 1; 计数是从0开始的
int startIndex = (pageNo - 1) * pageSize;
int endIndex = pageNo * pageSize - 1;
return jedis.lrange("blog_list", startIndex, endIndex);

队列FIFO

  • 秒杀请求。邮件服务器
jedis.lpush("sec_kill_request_queue", secKillRequest);
jedis.rpop("sec_kill_request_queue");

阻塞式获取发送邮件任务

// 第一个是阻塞时间
jedis.brpop(5, "send_mail_task_queue");

待办

// 插入待办事项
// 在 targetTodoEvent 前面  "插入的待办事项"
linsert(String key, ListPosition where, String pivot, String value);
jedis.linsert("todo_event::" + userId,  ListPosition.BEFORE
			, targetTodoEvent, "插入的待办事项");

// 修改一个待办事项
jedis.lset("todo_event::" + userId, index, updatedTodoEvent);
// 完成一个待办事项
jedis.lrem("todo_event::" + userId, 0, todoEvent);

set

博客标签

jedis.sadd("article::" + id + "::tags", tags);
Set<String> tags = jedis.smembers("article::" + id + "::tags");

抽奖

jedis.sadd("lottery_draw_event::" + lotteryDrawEventId +"::candidates", 
           String.valueOf(userId));
jedis.srandmember("lottery_draw_event::" + lotteryDrawEventId +"::candidates", 
                  count);

微博案例

// 关注
jedis.sadd("user::" + followUserId + "::followers", String.valueOf(userId));
jedis.sadd("user::" + userId + "::follow_users", String.valueOf(followUserId));

// 取消关注
jedis.srem("user::" + followUserId + "::followers", String.valueOf(userId));
jedis.srem("user::" + userId + "::follow_users", String.valueOf(followUserId));

jedis.smembers("user::" + userId + "::followers");
jedis.smembers("user::" + userId + "::follow_users");

// 查看个数
jedis.scard("user::" + userId + "::followers");
jedis.scard("user::" + userId + "::follow_users");

// 获取用户跟其他用户之间共同关注的人有哪些,注意都是follow_users
jedis.sinter("user::" + userId + "::follow_users",
             "user::" + otherUserId + "::follow_users");

// 获取给我推荐的可关注人
// 我关注的某个好友关注的一些人,我没关注那些人,此时推荐那些人给我
jedis.sdiff("user::" + otherUserId + "::follow_users",
            "user::" + userId + "::follow_users");

朋友圈点赞

// 点赞和取消点赞
jedis.sadd("moment_like_users::" + momentId, String.valueOf(userId));
jedis.srem("moment_like_users::" + momentId, String.valueOf(userId));

// 查看自己是否对某条朋友圈点赞过
jedis.sismember("moment_like_users::" + momentId, String.valueOf(userId));

// 获取你的一条朋友圈有哪些人点赞了
jedis.smembers("moment_like_users::" + momentId);

// 获取你的一条朋友圈被几个人点赞了
jedis.scard("moment_like_users::" + momentId);

商品搜索案例

//添加商品的时候附带一些关键词
// 一个关键词就加一个,某个关键词下面可能有多个商品
jedis.sadd("keyword::" + keyword + "::products", String.valueOf(productId));

// 根据多个关键词搜索商品()
keywordSetKeys.add("keyword::" + keyword + "::products");
String[] keywordArray = keywordSetKeys.toArray(new String[keywordSetKeys.size()]);
jedis.sinter(keywordArray);

网站UV统计

jedis.sadd("user_access::" + today, String.valueOf(userId));
jedis.scard("user_access::" + today);

投票统计

// 投票
jedis.sadd("vote_item_users::" + voteItemId, String.valueOf(userId));
// 检查用户对投票项是否投过票
jedis.sismember("vote_item_users::" + voteItemId, String.valueOf(userId));
// 获取一个投票项被哪些人投票了
jedis.smembers("vote_item_users::" + voteItemId);
// 获取一个投票项被多少人投票了
jedis.scard("vote_item_users::" + voteItemId);

zset

推荐商品

// 继续购买商品
jedis.zincrby("continue_purchase_products::" + productId, 1, 
              String.valueOf(otherProductId));

// 推荐其他人购买过的其他商品.3个
Set<Tuple> jedis.zrevrangeWithScores("continue_purchase_products::" + 
                                     productId, 0, 2);

新闻

jedis.zadd("news", timestamp, String.valueOf(newsId));
jedis.zrevrangeByScoreWithScores("news", maxTimestamp, minTimestamp, index, count);

排行榜

// 0 s是初始分数
jedis.zadd("music_ranking_list", 0, String.valueOf(songId));
jedis.zincrby("music_ranking_list", score, String.valueOf(songId));

// 获取排名
jedis.zrevrank("music_ranking_list", String.valueOf(songId));
// 排行榜
jedis.zrevrangeWithScores("music_ranking_list", 0, 2);

自动补全

将字符的每一个追加之后作为key,value就是整句话,分数是当前日期

使用的时候直接获取对应的key即可

public void add(String keyword) {
    char[] keywordCharArray = keyword.toCharArray();

    StringBuffer potentialKeyword = new StringBuffer("");

    // 我喜欢学习

    // 我:时间+我喜欢学习
    // 我喜:时间+我喜欢学习

    // 我爱大家
    // 我:时间+我爱大家

    for(char keywordChar : keywordCharArray) {
        potentialKeyword.append(keywordChar);

        jedis.zincrby(
            "potential_Keyword::" + potentialKeyword.toString() + "::keywords",
            new Date().getTime(),
            keyword);
    }
}

/**
     * 获取自动补全列表
     * @param potentialKeyword
     * @return
     */
public Set<String> getAutoCompleteList(String potentialKeyword) {
    return jedis.zrevrange("potential_Keyword::" + potentialKeyword + "::keywords",
                           0, 2);
}

posted on 2025-10-13 00:40  chuchengzhi  阅读(5)  评论(0)    收藏  举报

导航

杭州技术博主,专注分享云计算领域实战经验、技术教程与行业洞察, 打造聚焦云计算技术的垂直博客,助力开发者快速掌握云服务核心能力。

褚成志 云计算 技术博客