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

相关推荐
Pasregret7 分钟前
04-深入解析 Spring 事务管理原理及源码
java·数据库·后端·spring·oracle
Micro麦可乐7 分钟前
最新Spring Security实战教程(七)方法级安全控制@PreAuthorize注解的灵活运用
java·spring boot·后端·spring·intellij-idea·spring security
csjane107911 分钟前
Redis原理:rename命令
java·redis
牛马baby30 分钟前
Java高频面试之并发编程-02
java·开发语言·面试
教练 我想学编程36 分钟前
学习记录706@微信小程序+springboot项目 真机测试 WebSocket错误: {errMsg: Invalid HTTP status.}连接不上
spring boot·学习·微信小程序
uhakadotcom40 分钟前
EventBus:简化组件间通信的利器
android·java·github
纪元A梦1 小时前
分布式锁算法——基于ZooKeeper的分布式锁全面解析
java·分布式·算法·zookeeper
翻滚吧键盘1 小时前
spring打包,打包错误
java·后端·spring
_Djhhh1 小时前
基于SpringAOP面向切面编程的一些实践(日志记录、权限控制、统一异常处理)
java·spring boot·spring·maven·sprint
张张张3121 小时前
4.1学习总结 拼图小游戏+集合进阶
java·学习