From af731ab6e7fbda99d3c970a027d95c1991c84b0b Mon Sep 17 00:00:00 2001
From: zjh <zjh@888>
Date: 星期四, 07 三月 2024 18:24:12 +0800
Subject: [PATCH] zjh 本地 2024/03/7 --2

---
 ltkj-common/src/main/java/com/ltkj/common/core/redis/RedisCache.java |   25 ++++++++++++++++++++++---
 1 files changed, 22 insertions(+), 3 deletions(-)

diff --git a/ltkj-common/src/main/java/com/ltkj/common/core/redis/RedisCache.java b/ltkj-common/src/main/java/com/ltkj/common/core/redis/RedisCache.java
index fd83cf0..f4a63e0 100644
--- a/ltkj-common/src/main/java/com/ltkj/common/core/redis/RedisCache.java
+++ b/ltkj-common/src/main/java/com/ltkj/common/core/redis/RedisCache.java
@@ -8,6 +8,7 @@
 import java.util.concurrent.TimeUnit;
 
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.redis.connection.lettuce.LettuceConnectionFactory;
 import org.springframework.data.redis.core.BoundSetOperations;
 import org.springframework.data.redis.core.HashOperations;
 import org.springframework.data.redis.core.RedisTemplate;
@@ -25,13 +26,24 @@
     @Autowired
     public RedisTemplate redisTemplate;
 
+    public RedisTemplate setDataBase(int num) {
+        LettuceConnectionFactory connectionFactory = (LettuceConnectionFactory) redisTemplate.getConnectionFactory();
+        if (connectionFactory != null && num != connectionFactory.getDatabase()) {
+            connectionFactory.setDatabase(num);
+            this.redisTemplate.setConnectionFactory(connectionFactory);
+            connectionFactory.resetConnection();
+            connectionFactory.afterPropertiesSet();
+        }
+        return redisTemplate;
+    }
+
     /**
      * 缂撳瓨鍩烘湰鐨勫璞★紝Integer銆丼tring銆佸疄浣撶被绛�
      *
      * @param key   缂撳瓨鐨勯敭鍊�
      * @param value 缂撳瓨鐨勫��
      */
-    public <T> void setCacheObject(final String key, final T value) {
+    public <T> void setCacheObject(final String key, final Object value) {
         redisTemplate.opsForValue().set(key, value);
     }
 
@@ -88,6 +100,10 @@
      */
     public Boolean hasKey(String key) {
         return redisTemplate.hasKey(key);
+    }
+
+    public Boolean hasHKey(String key1,String key2) {
+        return redisTemplate.opsForHash().hasKey(key1,key2);
     }
 
     /**
@@ -195,12 +211,15 @@
      *
      * @param key   Redis閿�
      * @param hKey  Hash閿�
-     * @param value 鍊�
      */
-    public <T> void setCacheMapValue(final String key, final String hKey, final T value) {
+    public <T> void setCacheMapValue(final String key, final String hKey, final Object value) {
         redisTemplate.opsForHash().put(key, hKey, value);
     }
 
+    public <T> void setHashKeyExpireTime(final String key, final Long time, final TimeUnit  unit) {
+        redisTemplate.expire(key,time,unit);
+    }
+
     /**
      * 鑾峰彇Hash涓殑鏁版嵁
      *

--
Gitblit v1.8.0