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字段。

相关推荐
sheji34166 小时前
【开题答辩全过程】以 基于Java的应急安全学习平台的设计与实现为例,包含答辩的问题和答案
java·开发语言·学习
程序员小假6 小时前
我们来说一下消息的可靠性投递
java·后端
席之郎小果冻6 小时前
【04】【创建型】【聊一聊,建造者模式】
java·前端·建造者模式
原来是好奇心6 小时前
深入Spring Boot源码(四):Starter机制与依赖管理深度解析
java·源码·springboot·starter
阿杆6 小时前
如何在 Spring Boot 中接入 Amazon ElastiCache
java·数据库·redis
cheems95277 小时前
锁策略的介绍
java·开发语言
pingzhuyan7 小时前
微服务: springboot整合kafka实现消息的简单收发(上)
spring boot·微服务·kafka
武子康7 小时前
Java-199 JMS Queue/Topic 集群下如何避免重复消费:ActiveMQ 虚拟主题与交付语义梳理
java·分布式·消息队列·rabbitmq·activemq·mq·java-activemq
LSL666_7 小时前
12 MyBatis的连接池
java·服务器·mybatis
Arva .7 小时前
说说线程的生命周期和状态
java·开发语言