redisTemplate的日常使用hash类型

redisTemplate.getExpire(key,TimeUnit.SECONDS);

这个方法,是使用redisTemplate获取到设置的过期时间。如果传入单位,则按照该单位的数据进行返回。

redisTemplate.getExpire(key);

返回的Long类型的时间单位是秒

redis 存储对象的方式:

数据格式

  1. 用户id为查找的key
  2. 存储的value用户对象包括姓名,年龄,生日等等
  3. 如果用普通的key-value结构来存储,主要有以下2种方式存储

方式一(String)

这种方式是使用list或者set这些来存储的,这样的方式其实也可以达到我们想要的效果,但是因为每次修改属性都需要三步走,性能开销非常大。1.先反序列化;2,修改;3.序列化

方式二(hash)

这种方式其实也有两种写法

写法一

这种写法不仅能够达成目标,而且解决了资源消耗过大的问题,但是也引起了另一个问题,就是用户的id数据冗余

写法二

通过key(用户id)+field(属性标签)可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并修复操控的问题 

opsForHash的使用

1、put(H key, HK hashKey, HV value)

新增hashMap值。

redisTemplate.opsForHash().put("hashValue","map1","map1-1");  
redisTemplate.opsForHash().put("hashValue","map2","map2-2");  

2、values(H key)

获取指定变量中的hashMap值。

List<Object> hashList = redisTemplate.opsForHash().values("hashValue");  
System.out.println("通过values(H key)方法获取变量中的hashMap值:" + hashList);  

3、entries(H key)

获取变量中的键值对。

Map<Object,Object> map = redisTemplate.opsForHash().entries("hashValue");  
System.out.println("通过entries(H key)方法获取变量中的键值对:" + map);  

4、get(H key, Object hashKey)

 获取变量中的指定map键是否有值,如果存在该map键则获取值,没有则返回null。

Object mapValue = redisTemplate.opsForHash().get("hashValue","map1");  
System.out.println("通过get(H key, Object hashKey)方法获取map键的值:" + mapValue);  

5、hasKey(H key, Object hashKey)

 判断变量中是否有指定的map键。

boolean hashKeyBoolean = redisTemplate.opsForHash().hasKey("hashValue","map3");  
System.out.println("通过hasKey(H key, Object hashKey)方法判断变量中是否存在map键:" + hashKeyBoolean);  

6、keys(H key)

获取变量中的键。

Set<Object> keySet = redisTemplate.opsForHash().keys("hashValue");  
System.out.println("通过keys(H key)方法获取变量中的键:" + keySet);  

7、size(H key)

 获取变量的长度。

long hashLength = redisTemplate.opsForHash().size("hashValue");  
System.out.println("通过size(H key)方法获取变量的长度:" + hashLength);  

8、increment(H key, HK hashKey, double delta)

使变量中的键以double值的大小进行自增长。

double hashIncDouble = redisTemplate.opsForHash().increment("hashInc","map1",3);  
System.out.println("通过increment(H key, HK hashKey, double delta)方法使变量中的键以值的大小进行自增长:" + hashIncDouble); 

9、increment(H key, HK hashKey, long delta)

使变量中的键以long值的大小进行自增长。

long hashIncLong = redisTemplate.opsForHash().increment("hashInc","map2",6);  
System.out.println("通过increment(H key, HK hashKey, long delta)方法使变量中的键以值的大小进行自增长:" + hashIncLong);  

10、multiGet(H key, Collection<HKhashKey)

 以集合的方式获取变量中的值。

List<Object> list = new ArrayList<Object>();  
list.add("map1");  
list.add("map2");  
List mapValueList = redisTemplate.opsForHash().multiGet("hashValue",list);  
System.out.println("通过multiGet(H key, Collection<HK> hashKeys)方法以集合的方式获取变量中的值:"+mapValueList);  

11、putAll(H key, Map<? extends HK,? extends HV> m)

以map集合的形式添加键值对。

Map newMap = new HashMap();  
newMap.put("map3","map3-3");  
newMap.put("map5","map5-5");  
redisTemplate.opsForHash().putAll("hashValue",newMap);  
map = redisTemplate.opsForHash().entries("hashValue");  
System.out.println("通过putAll(H key, Map<? extends HK,? extends HV> m)方法以map集合的形式添加键值对:" + map);  

12、putIfAbsent(H key, HK hashKey, HV value)

如果变量值存在,在变量中可以添加不存在的的键值对,如果变量不存在,则新增一个变量,同时将键值对添加到该变量。

redisTemplate.opsForHash().putIfAbsent("hashValue","map6","map6-6");  
map = redisTemplate.opsForHash().entries("hashValue");  
System.out.println("通过putIfAbsent(H key, HK hashKey, HV value)方法添加不存在于变量中的键值对:" + map);  


Cursor<Map.Entry<Object,Object>> cursor = redisTemplate.opsForHash().scan("hashValue",ScanOptions.scanOptions().match("map1").build());  
//Cursor<Map.Entry<Object,Object>> cursor = redisTemplate.opsForHash().scan("hashValue",ScanOptions.NONE);  
while (cursor.hasNext()){  
    Map.Entry<Object,Object> entry = cursor.next();  
    System.out.println("通过scan(H key, ScanOptions options)方法获取匹配键值对:" + entry.getKey() + "---->" + entry.getValue());  

14、delete(H key, Object... hashKeys)

删除变量中的键值对,可以传入多个参数,删除多个键值对。

redisTemplate.opsForHash().delete("hashValue","map1","map2");  
map = redisTemplate.opsForHash().entries("hashValue");  
System.out.println("通过delete(H key, Object... hashKeys)方法删除变量中的键值对后剩余的:" + map);

  • 4
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Spring Boot 中使用 RedisTemplate 存储 hash 类型的数据到 Redis,可以使用以下步骤: 1. 在 pom.xml 文件中添加 Redis 的依赖: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 2. 在 application.properties 或 application.yml 中配置 Redis 连接信息: ``` spring.redis.host=your_redis_host spring.redis.port=your_redis_port ``` 3. 在需要使用 Redis 的类中注入 RedisTemplate 对象: ``` @Autowired private RedisTemplate<String, Object> redisTemplate; ``` 4. 使用 redisTemplatehash 相关方法来存储数据,如 hset()、hget()、hdel() 等。 示例代码: ``` redisTemplate.opsForHash().put("hashName","key","value"); redisTemplate.opsForHash().get("hashName","key"); ``` 注意: RedisTemplate 默认会使用 JDK 序列化器来序列化对象,如果需要使用 JSON 序列化器,需要在配置类中进行配置。 ### 回答2: 在Spring Boot中使用RedisTemplate存放hash类型Redis,我们需要进行以下步骤: 1. 配置RedisTemplate 首先,在Spring Boot的配置文件(例如application.properties)中配置Redis的连接信息,包括主机地址、端口号、密码等。可以使用以下配置代码: ```java spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password=yourpassword ``` 然后,在你的Spring Boot应用程序中创建一个RedisTemplate的Bean,并设置相关的Redis连接工厂、Key和Value的序列化方式等配置项。 2. 使用RedisTemplate操作hash类型 在你的代码中,注入RedisTemplate,并使用它对Redis中的hash类型进行操作。例如,你可以在某个Service类中使用RedisTemplate进行hash的存储和获取操作,示例如下: ```java @Service public class RedisHashService { @Autowired private RedisTemplate<String, Object> redisTemplate; public void saveHash(String key, Map<String, Object> hash) { redisTemplate.opsForHash().putAll(key, hash); } public Map<Object, Object> getHash(String key) { return redisTemplate.opsForHash().entries(key); } } ``` 在上述示例中,`saveHash`方法使用RedisTemplate的`opsForHash`方法来将一个Map对象保存为hash类型的数据到Redis中。`getHash`方法则使用`opsForHash`方法获取指定hash的所有字段和值,返回一个Map对象。 这样,你就可以在Spring Boot中使用RedisTemplate存放hash类型Redis了。通过注入RedisTemplate,并使用其提供的操作方法,你可以方便地进行哈希类型的数据存储和获取操作。 ### 回答3: 在Spring Boot中使用RedisTemplate存储hash类型数据到Redis,可以按照以下步骤进行操作: 首先,我们需要在Spring Boot项目中引入Redis依赖,在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 接下来需要配置Redis连接信息,可以在application.properties文件中添加以下配置: ```properties spring.redis.host=127.0.0.1 spring.redis.port=6379 ``` 然后,在需要使用Redis的类中注入RedisTemplate实例: ```java @Autowired private RedisTemplate<String, Object> redisTemplate; ``` 接下来就可以使用RedisTemplate存储hash类型数据到Redis了。假设我们要存储一个名为"myHash"的hash数据到Redis,可以使用以下代码: ```java String hashKey = "myHash"; String field1 = "field1"; String value1 = "value1"; String field2 = "field2"; String value2 = "value2"; redisTemplate.opsForHash().put(hashKey, field1, value1); redisTemplate.opsForHash().put(hashKey, field2, value2); ``` 可以使用opsForHash()方法获取HashOperations对象,然后调用put()方法将指定字段和对应值存储到hash中。 当然,还可以使用其他的方法进行操作,例如获取hash中指定字段的值、获取全部字段和值等等。详细的操作可以查看RedisTemplateHashOperations类中的方法。 最后,记得在应用程序关闭时释放Redis连接资源。 以上就是使用RedisTemplate存储hash类型数据到Redis的简要步骤,希望对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值