《Redis应用实例》Java实现(24):时间线

15 阅读1分钟

对于一些与时间或日期密切关联的应用,分页是基于时间的。 比如博客系统,用户可能只对对特定时间段的文章感兴趣,例如,他想查看在2023年至2025年发表的文章,诸如此类。 可以利用reids的zset来实现这个功能。

package com.foxbill.redisinaction;

import redis.clients.jedis.Jedis;
import java.util.List;
import java.util.stream.Collectors;

/**
 * 时间线
 */
public class Chapter24 {
    static private String KEY_TIMELINE = "Chapter24:timeline";

    static public void start(Jedis jedis) {
        cleanData(jedis);
        initData(jedis);
        //
        long total = count(jedis);
        System.out.printf("total: %d\n", total);
        //
        int page=2;
        int pageSize=10;
        List<String> pageData = get(jedis, page, pageSize);
        String strData = pageData.stream().collect(Collectors.joining(","));
        System.out.printf("page %d\n%s\n",page,strData);

        page=3;
        pageData = get(jedis, page, pageSize);
        strData = pageData.stream().collect(Collectors.joining(","));
        System.out.printf("page %d\n%s\n",page,strData);
    }

    //清除数据
    private static void cleanData(Jedis jedis) {
        jedis.del(KEY_TIMELINE);
    }

    //初始化数据
    private static void initData(Jedis jedis) {
        long begintTimeStamp = 1748702000;
        for (int i = 0; i < 34; i++) {
            jedis.zadd(KEY_TIMELINE,begintTimeStamp+1000*i,"item:"+String.valueOf(i));
        }
    }

    private static List<String> get(Jedis jedis,int page,int pageSize) {
        int start = (page - 1) * pageSize;
        int end = page * pageSize-1;
        List<String> result = jedis.zrange(KEY_TIMELINE,start,end);
        return result;
    }

    private static long count(Jedis jedis) {
        long llen = jedis.zcard(KEY_TIMELINE);
        return llen;
    }
}