Redis 从入门到精通之Redis List数据结构操作命令和示例

简介: 使用Jedis和RedisTemplate分别实现Redis列表操作的示例。Redis列表是一个有序的字符串列表,可以在列表的头部或尾部添加、删除元素,还可以截取、查看、修改元素,以及实现阻塞队列等功能。还可以使用其他编程语言的Redis客户端库实现Redis列表操作,如Python的redis模块、Java的Lettuce等。

1.Redis List操作命令

1.1 添加元素

    • 从左侧添加元素:LPUSH key element [element ...]

      > LPUSH fruits apple orange banana
      (integer) 3
      
    • 从右侧添加元素:RPUSH key element [element ...]

      > RPUSH fruits grape
      (integer) 4
      
    • 查看列表长度:LLEN key

      > LLEN fruits
      (integer) 4
      

1.2 查看元素

    • 获取指定下标的元素:LINDEX key index

      > LINDEX fruits 1
      "orange"
      
    • 获取指定范围内的元素:LRANGE key start stop

      > LRANGE fruits 0 2
      1) "banana"
      2) "orange"
      3) "apple"
      
    • 截取list:LTRIM key start stop

      > LTRIM fruits 1 2
      OK
      > LRANGE fruits 0 -1
      1) "orange"
      2) "banana"
      

1.3 删除元素:

- 删除指定元素:`LREM key count element`

  ```redis
  > LPUSH numbers 1 2 3 2 4 5 2
  (integer) 7
  > LREM numbers 2 2
  (integer) 2
  > LRANGE numbers 0 -1
  1) "5"
  2) "4"
  3) "3"
  4) "1"
  ```

- 从左侧删除元素:`LPOP key`

  ```redis
  > LPOP fruits
  "orange"
  > LRANGE fruits 0 -1
  1) "banana"
  2) "apple"
  ```

- 从右侧删除元素:`RPOP key`

  ```redis
  > RPOP fruits
  "apple"
  > LRANGE fruits 0 -1
  1) "banana"
  ```
  • 设置list中指定下标的元素值:LSET key index element

    > LSET fruits 1 lemon
    OK
    > LRANGE fruits 0 -1
    1) "banana"
    2) "lemon"
    

1.4 阻塞队列:

- 从左侧取出元素(如果列表为空则阻塞):`BLPOP key timeout`

  ```redis
  > BLPOP fruits 10
  1) "fruits"
  2) "banana"
  ```

- 从右侧取出元素(如果列表为空则阻塞):`BRPOP key timeout`

  ```redis
  > BRPOP fruits 10
  1) "fruits"
  2) "lemon"
  ```

- 阻塞地从多个列表中取出元素(如果所有列表都为空则阻塞):`BRPOPLPUSH source destination timeout`

  ```redis
  > BRPOPLPUSH fruits fruits_copy 10
  "banana"
  > LRANGE fruits_copy 0 -1
  1) "banana"
  ```

2.Jedis和RedisTemplate代码示例

2.1 Jedis实现:

import redis.clients.jedis.Jedis;

public class JedisExample {
   
    public static void main(String[] args) {
   
        // 连接Redis
        Jedis jedis = new Jedis("localhost", 6379);

        // 添加元素
        jedis.lpush("fruits", "apple", "orange", "banana");
        jedis.rpush("fruits", "grape");

        // 查看列表长度
        System.out.println(jedis.llen("fruits"));

        // 查看元素
        System.out.println(jedis.lindex("fruits", 1));
        System.out.println(jedis.lrange("fruits", 0, 2));

        // 截取list
        jedis.ltrim("fruits", 1, 2);
        System.out.println(jedis.lrange("fruits", 0, -1));

        // 删除元素
        jedis.lrem("fruits", 1, "orange");
        jedis.lpop("fruits");
        jedis.rpop("fruits");

        // 设置list中指定下标的元素值
        jedis.lset("fruits", 1, "lemon");
        System.out.println(jedis.lrange("fruits", 0, -1));

        // 阻塞队列
        // 从左侧阻塞地取出元素
        System.out.println(jedis.blpop(10, "fruits"));
        // 从右侧阻塞地取出元素
        System.out.println(jedis.brpop(10, "fruits"));
        // 阻塞地从source列表取出元素并插入到destination列表中
        System.out.println(jedis.brpoplpush("fruits", "fruits_copy", 10));

        // 关闭连接
        jedis.close();
    }
}

2.1 RedisTemplate实现:

import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ListOperations;
import org.springframework.data.redis.serializer.StringRedisSerializer;

public class RedisTemplateExample {
   
    public static void main(String[] args) {
   
        // 创建RedisTemplate对象
        RedisTemplate<String, String> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(new JedisConnectionFactory());

        // 设置key和value的序列化方式
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(new StringRedisSerializer());

        // 初始化RedisTemplate
        redisTemplate.afterPropertiesSet();

        // 获取List类型操作对象
        ListOperations<String, String> listOps = redisTemplate.opsForList();

        // 添加元素
        listOps.leftPush("fruits", "apple");
        listOps.leftPush("fruits", "orange");
        listOps.leftPush("fruits", "banana");
        listOps.rightPush("fruits", "grape");

        // 查看列表长度
        System.out.println(listOps.size("fruits"));

        // 查看元素
        System.out.println(listOps.index("fruits", 1));
        System.out.println(listOps.range("fruits", 0, 2));

        // 截取list
        listOps.trim("fruits", 1, 2);
        System.out.println(listOps.range("fruits", 0, -1));

        // 删除元素
        listOps.remove("fruits", 1, "orange");
        listOps.leftPop("fruits");
        listOps.rightPop("fruits");

        // 设置list中指定下标的元素值
        listOps.set("fruits", 1, "lemon");
        System.out.println(listOps.range("fruits", 0, -1));

        // 阻塞队列
        // 从左侧阻塞地取出元素
        System.out.println(listOps.leftPop("fruits", 10, TimeUnit.SECONDS));
        // 从右侧阻塞地取出元素
        System.out.println(listOps.rightPop("fruits", 10, TimeUnit.SECONDS));
        // 阻塞地从source列表取出元素并插入到destination列表中
        System.out.println(listOps.rightPopAndLeftPush("fruits", "fruits_copy", 10, TimeUnit.SECONDS));

        // 关闭RedisTemplate连接
        redisTemplate.getConnectionFactory().getConnection().close();
    }
}

3.总结

使用Jedis和RedisTemplate分别实现Redis列表操作的示例。Redis列表是一个有序的字符串列表,可以在列表的头部或尾部添加、删除元素,还可以截取、查看、修改元素,以及实现阻塞队列等功能。还可以使用其他编程语言的Redis客户端库实现Redis列表操作,如Python的redis模块、Java的Lettuce等。

目录
相关文章
|
3月前
|
消息中间件 缓存 NoSQL
Redis各类数据结构详细介绍及其在Go语言Gin框架下实践应用
这只是利用Go语言和Gin框架与Redis交互最基础部分展示;根据具体业务需求可能需要更复杂查询、事务处理或订阅发布功能实现更多高级特性应用场景。
306 86
|
3月前
|
存储 消息中间件 NoSQL
Redis数据结构:别小看这5把“瑞士军刀”,用好了性能飙升!
Redis提供5种基础数据结构及多种高级结构,如String、Hash、List、Set、ZSet,底层通过SDS、跳表等实现高效操作。灵活运用可解决缓存、计数、消息队列、排行榜等问题,结合Bitmap、HyperLogLog、GEO更可应对签到、UV统计、地理位置等场景,是高性能应用的核心利器。
|
3月前
|
存储 缓存 NoSQL
Redis基础命令与数据结构概览
Redis是一个功能强大的键值存储系统,提供了丰富的数据结构以及相应的操作命令来满足现代应用程序对于高速读写和灵活数据处理的需求。通过掌握这些基础命令,开发者能够高效地对Redis进行操作,实现数据存储和管理的高性能方案。
123 12
|
3月前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
7月前
|
存储 缓存 监控
Redis设计与实现——Redis命令参考与高级特性
Redis 是一个高性能的键值存储系统,支持丰富的数据类型(字符串、列表、哈希、集合等)和多种高级功能。本文档涵盖 Redis 的核心命令分类,包括数据类型操作、事务与脚本、持久化、集群管理、系统监控等。特别介绍了事务的原子性特性、Lua 脚本的执行方式及优势、排序机制、发布订阅模型以及慢查询日志和监视器工具的使用方法。适用于开发者快速掌握 Redis 常用命令及其应用场景,优化系统性能与可靠性。
|
7月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?

热门文章

最新文章