征服 Redis + Jedis + Spring (三)—— 列表操作

本文介绍如何使用Spring Data Redis中的StringRedisTemplate实现List的基本操作,包括压栈、出栈、入队、出队等,并提供了具体的Java代码示例。

通过spring-data-redis完成LINDEX, LLEN, LPOP, LPUSH, LRANGE, LREM, LSET, LTRIM, RPOP, RPUSH命令。其实还有一些命令,当前版本不支持。皱眉不过,这些List的操作方法可以实现队列,堆栈的正常操作,足够用了。

为了简便操作,我使用了StringRedisTemplate。用字符串操作做展示。当然,你可以继续使用RedisTemplate。

闲言少叙,上代码,一目了然:

Java代码 收藏代码
  1. /**
  2. *Mar5,2013
  3. */
  4. packageorg.zlex.redis.support;
  5. importjava.util.List;
  6. importorg.springframework.beans.factory.annotation.Autowired;
  7. importorg.springframework.data.redis.core.StringRedisTemplate;
  8. importorg.springframework.stereotype.Component;
  9. /**
  10. *
  11. *@authorsnowolf
  12. *@version1.0
  13. *@since1.0
  14. */
  15. @Component("listOps")
  16. publicclassListOps{
  17. @Autowired
  18. privateStringRedisTemplatestringRedisTemplate;
  19. /**
  20. *压栈
  21. *
  22. *@paramkey
  23. *@paramvalue
  24. *@return
  25. */
  26. publicLongpush(Stringkey,Stringvalue){
  27. returnstringRedisTemplate.opsForList().leftPush(key,value);
  28. }
  29. /**
  30. *出栈
  31. *
  32. *@paramkey
  33. *@return
  34. */
  35. publicStringpop(Stringkey){
  36. returnstringRedisTemplate.opsForList().leftPop(key);
  37. }
  38. /**
  39. *入队
  40. *
  41. *@paramkey
  42. *@paramvalue
  43. *@return
  44. */
  45. publicLongin(Stringkey,Stringvalue){
  46. returnstringRedisTemplate.opsForList().rightPush(key,value);
  47. }
  48. /**
  49. *出队
  50. *
  51. *@paramkey
  52. *@return
  53. */
  54. publicStringout(Stringkey){
  55. returnstringRedisTemplate.opsForList().leftPop(key);
  56. }
  57. /**
  58. *栈/队列长
  59. *
  60. *@paramkey
  61. *@return
  62. */
  63. publicLonglength(Stringkey){
  64. returnstringRedisTemplate.opsForList().size(key);
  65. }
  66. /**
  67. *范围检索
  68. *
  69. *@paramkey
  70. *@paramstart
  71. *@paramend
  72. *@return
  73. */
  74. publicList<String>range(Stringkey,intstart,intend){
  75. returnstringRedisTemplate.opsForList().range(key,start,end);
  76. }
  77. /**
  78. *移除
  79. *
  80. *@paramkey
  81. *@parami
  82. *@paramvalue
  83. */
  84. publicvoidremove(Stringkey,longi,Stringvalue){
  85. stringRedisTemplate.opsForList().remove(key,i,value);
  86. }
  87. /**
  88. *检索
  89. *
  90. *@paramkey
  91. *@paramindex
  92. *@return
  93. */
  94. publicStringindex(Stringkey,longindex){
  95. returnstringRedisTemplate.opsForList().index(key,index);
  96. }
  97. /**
  98. *置值
  99. *
  100. *@paramkey
  101. *@paramindex
  102. *@paramvalue
  103. */
  104. publicvoidset(Stringkey,longindex,Stringvalue){
  105. stringRedisTemplate.opsForList().set(key,index,value);
  106. }
  107. /**
  108. *裁剪
  109. *
  110. *@paramkey
  111. *@paramstart
  112. *@paramend
  113. */
  114. publicvoidtrim(Stringkey,longstart,intend){
  115. stringRedisTemplate.opsForList().trim(key,start,end);
  116. }
  117. }

这里说明下,例如LPUSH,RPUSH,其实就是从左边压栈,还是从右边压栈的不同命令。可以把堆栈看作是一个从左至右的数组。如果左边压栈,右边出栈,那就是队列的入队/出队操作;如果左边压栈,左边出栈,那就是堆栈操作。

举个具体的例子:

队列操作:LPUSH入队,RPOP出队,同理,可把L|R替换。

堆栈操作:LPUSH压栈,LPOP出栈,同理,可把L|R替换。

下面进行测试用例,初始、结束时,分别做入队、出队操作,期间进行堆栈,队列操作。不用我细说了,看测试用例,很简单!

Java代码 收藏代码
  1. /**
  2. *Mar5,2013
  3. */
  4. packageorg.zlex.redis;
  5. importstaticorg.junit.Assert.*;
  6. importjava.util.List;
  7. importorg.junit.Before;
  8. importorg.junit.After;
  9. importorg.junit.Test;
  10. importorg.springframework.context.ApplicationContext;
  11. importorg.springframework.context.support.ClassPathXmlApplicationContext;
  12. importorg.zlex.redis.support.ListOps;
  13. /**
  14. *
  15. *@authorsnowolf
  16. *@version1.0
  17. *@since1.0
  18. */
  19. publicclassListOpsTest{
  20. privateApplicationContextapp;
  21. privateListOpslistOps;
  22. privateStringkey="queue";
  23. @Before
  24. publicvoidbefore()throwsException{
  25. app=newClassPathXmlApplicationContext("applicationContext.xml");
  26. listOps=(ListOps)app.getBean("listOps");
  27. System.out.println("------------IN---------------");
  28. for(inti=0;i<5;i++){
  29. Stringuid="u"+i;
  30. System.out.println(uid);
  31. listOps.in(key,uid);
  32. }
  33. }
  34. @After
  35. publicvoidafter(){
  36. //------------OUT---------------
  37. System.out.println("------------OUT---------------");
  38. longlength=listOps.length(key);
  39. for(longi=0;i<length;i++){
  40. Stringuid=listOps.out(key);
  41. System.out.println(uid);
  42. }
  43. }
  44. @Test
  45. publicvoidstack(){
  46. //------------PUSH---------------
  47. Stringkey="stack";
  48. intlen=5;
  49. System.out.println("------------PUSH---------------");
  50. for(inti=0;i<len;i++){
  51. Stringuid="u"+System.currentTimeMillis();
  52. System.out.println(uid);
  53. listOps.push(key,uid);
  54. }
  55. longlength=listOps.length(key);
  56. assertEquals(len,length);
  57. //------------POP---------------
  58. System.out.println("------------POP---------------");
  59. for(longi=0;i<length;i++){
  60. Stringuid=listOps.pop(key);
  61. System.out.println(uid);
  62. }
  63. }
  64. @Test
  65. publicvoidindex(){
  66. //-------------INDEX-------------
  67. Stringvalue=listOps.index(key,3);
  68. assertEquals("u3",value);
  69. }
  70. @Test
  71. publicvoidrange(){
  72. //-------------RANGE-------------
  73. List<String>list=listOps.range(key,3,5);
  74. booleanresult1=list.contains("u3");
  75. assertEquals(true,result1);
  76. booleanresult2=list.contains("u1");
  77. assertEquals(false,result2);
  78. }
  79. @Test
  80. publicvoidtrim(){
  81. //------------TRIM---------------
  82. List<String>list=listOps.range(key,3,5);
  83. listOps.trim(key,3,5);
  84. booleanresult3=list.contains("u1");
  85. assertEquals(false,result3);
  86. }
  87. @Test
  88. publicvoidset(){
  89. //------------SET-----------------
  90. List<String>list=listOps.range(key,3,5);
  91. listOps.set(key,4,"ux4");
  92. booleanresult4=list.contains("u4");
  93. assertEquals(true,result4);
  94. }
  95. @Test
  96. publicvoidremove(){
  97. //------------REMOVE-----------------
  98. listOps.remove(key,4,"u4");
  99. Stringvalue=listOps.index(key,4);
  100. assertEquals(null,value);
  101. }
  102. }

回头继续整理,这个套路没错!酷

### Spring Boot 3与Redis集成使用Jedis客户端 #### 集成概述 为了使Spring Boot应用程序能够连接并操作Redis数据库,通常会引入特定的库来简化这一过程。对于采用Jedis作为底层通信工具的情况,在Spring Boot项目中集成就显得尤为重要[^1]。 #### 添加依赖项 在`pom.xml`文件内加入如下Maven依赖声明: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <!-- 如果需要指定版本 --> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <!-- 版本号应根据实际情况调整 --> </dependency> ``` 上述配置确保了应用具备访问Redis所需的基础组件以及Jedis驱动程序的支持能力[^2]。 #### 自定义配置类 创建名为`RedisConfig.java`的新Java类用于定制化设置: ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import redis.clients.jedis.JedisPool; import redis.clients.jedis.JedisPoolConfig; @Configuration public class RedisConfig { @Bean public JedisPool jedisPool() { final String host = "localhost"; // 替换为实际服务器地址 int port = 6379; // 默认端口 JedisPoolConfig poolConfig = new JedisPoolConfig(); return new JedisPool(poolConfig, host, port); } } ``` 这段代码片段展示了如何通过编程方式构建一个可重用的Jedis连接池实例,并将其注册给Spring容器管理[^3]。 #### 应用属性配置 编辑位于资源路径下的`application.properties`或`application.yml`文件,添加必要的参数以便更好地控制Redis行为: ```properties # application.properties 示例 spring.redis.host=localhost spring.redis.port=6379 ``` 或者如果是YAML格式,则看起来像这样: ```yaml # application.yml 示例 spring: redis: host: localhost port: 6379 ``` 这些设定允许开发者轻松更改目标Redis服务的位置和其他选项而无需修改任何源代码逻辑[^4]。 #### 测试连接功能 最后一步是在控制器或其他业务层组件里验证能否成功建立至Redis的数据链路。这里给出一段简单的测试方法实现: ```java @RestController @RequestMapping("/api/redis") public class RedisController { private static final Logger logger = LoggerFactory.getLogger(RedisController.class); @Autowired private JedisPool jedisPool; @GetMapping("/testConnection") public ResponseEntity<String> testConnection(){ try (Jedis jedis = jedisPool.getResource()){ String pongResponse = jedis.ping(); if ("PONG".equals(pongResponse)){ return ResponseEntity.ok("Connected to Redis successfully!"); }else{ return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Failed to connect."); } } catch(Exception e){ logger.error(e.getMessage(),e); return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("An error occurred while connecting."); } } } ``` 此接口提供了一个便捷的方式去确认当前环境是否已经正确设置了通往Redis的服务通道[^5]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值