Redis-13.在Java中操作Redis-Spring Data Redis使用方式-操作哈希类型的数据

一.操作哈希类型的数据

java 复制代码
package com.sky.test;

import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.*;

import java.util.List;
import java.util.Set;
import java.util.concurrent.TimeUnit;

@SpringBootTest
public class SpringDataRedisTest {
    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void testRedisTemplate() {
        System.out.println(redisTemplate);  // 首先输出redisTemplate对象看是否为空
        ValueOperations valueOperations = redisTemplate.opsForValue();  // redis当中的字符串类型数据操作对象
        HashOperations hashOperations = redisTemplate.opsForHash();     // redis当中的哈希类型数据操作对象
        ListOperations listOperations = redisTemplate.opsForList();     // redis当中的列表类型数据操作对象
        SetOperations setOperations = redisTemplate.opsForSet();        // redis当中的集合类型数据操作对象
        ZSetOperations zSetOperations = redisTemplate.opsForZSet();     // redis当中的有序集合类型数据操作对象
    }

    /*
        操作字符串类型的数据
     */
    @Test
    public void testString() {
        // set get setex setnx
        redisTemplate.opsForValue().set("city","北京");   // set
        String city = (String) redisTemplate.opsForValue().get("city");// get
        System.out.println(city);
        redisTemplate.opsForValue().set("code","1234",3, TimeUnit.MINUTES);     // setex
        redisTemplate.opsForValue().setIfAbsent("lock","1");   // setnx
        redisTemplate.opsForValue().setIfAbsent("lock","2");
    }

    /*
        操作哈希类型的数据
     */
    @Test
    public void testHash() {
        // hset hget hdel hkeys hvals
        HashOperations hashOperations = redisTemplate.opsForHash();
        hashOperations.put("100","name","tom");    // put(Object key,Object hashKey,Object value)
        hashOperations.put("100","age","20");   // 对应hset
        String name = (String) hashOperations.get("100", "name");   // 对应hget
        System.out.println(name);

        Set keys = hashOperations.keys("100");      // 对应hkeys

        List values = hashOperations.values("100");     // 对应hvals

        hashOperations.delete("100","age");  // 对应hdel
    }
}

操作哈希类型的数据时,我们使用redisTemplate对象的opsForHash()方法,生成一个HashOperations对象hashOperations用来在redis数据库中创建数据。

1.put方法

用来往redis数据库中插入数据,其语法为put(Object key, Object hashKey, Object value)。如插入键为100,field为"name",value为"tom"的数据。

插入第二条。

2.get方法

用来获取指定key中field的value,

hashOperations.get("100", "name")。

3.keys方法

获取key中所对应的所有fields,并封装在一个set集合中。如获取key为100的fields的List集合。

4.values方法

获取key中所对应的所有values,并封装在一个List集合中。

如获取key为100的values的List集合。

5.delete方法

删除对应key中的field字段以及value值。 如删除key为100中的age字段。

无age字段。

相关推荐
SoFlu软件机器人3 小时前
飞算 JavaAI 与 Spring Boot:如何实现微服务开发效率翻倍?
spring boot·后端·微服务
不当菜虚困4 小时前
JAVA设计模式——(二)组合模式
java·设计模式·组合模式
jack_xu5 小时前
经典大厂面试题——缓存穿透、缓存击穿、缓存雪崩
java·redis·后端
CHQIUU6 小时前
Java 设计模式心法之第4篇 - 单例 (Singleton) 的正确打开方式与避坑指南
java·单例模式·设计模式
碎梦归途6 小时前
23种设计模式-结构型模式之享元模式(Java版本)
java·开发语言·jvm·设计模式·享元模式
菜萝卜子6 小时前
【Redis】redis主从哨兵
数据库·redis·缓存
backRoads6 小时前
docker部署springboot(eureka server)项目
spring boot·docker·eureka
lozhyf6 小时前
Eureka搭建
java·spring cloud
幽络源小助理6 小时前
SpringBoot民宿管理系统开发实现
java·spring boot·springboot·民宿系统
东阳马生架构6 小时前
Nacos简介—1.Nacos使用简介
java