Redis-12.在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.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() {
        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");
    }
}

这里我们使用的是10号数据库,因为我们在配置文件中配置的是10号数据库。我们使用opsForValue()方法来对redis当中的字符串类型的数据进行操作。

1.使用set来进行redis数据库中字符串类型数据的添加

2.使用get查询redis数据库当中字符串类型数据的value

3.使用set(Object key, Object value, long timeout, TimeUnit unit)设置数据库中数据的过期时间,对应redis中的setex命令

4.使用setIfAbsent(Object key, Object value)设置数据库中的数据,如果不存在就加入数据库,如果存在就不加入,对应redis中的setnx命令

之后可以从数据库可视化工具中查看DB10号数据库中的数据内容:

redis当中get到的数据是Object类型的,因此要使用强制类型转换。此外,redis当中的String和Java当中的String有区别,因此会使得其在java当中get到的字符串和redis当中的字符串有区别,如在当前例子中Java中get到的是正常输入,而redis当中会乱码。 code不存在是因为该键值对已过期

lock当中存储的字符串1而不是2,那是因为使用setIfAbsent的话当数据库中的键已存在时,再插入同样键的新值不会生效。

相关推荐
Deepincode15 分钟前
Redis源码探究系列—跳表(skiplist)源码实现详解
redis
专注API从业者40 分钟前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
摇滚侠1 小时前
DBeaver 导入数据库 导入 SQL 文件 MySQL 备份恢复
java·数据库·mysql
keep one's resolveY1 小时前
SpringBoot实现重试机制的四种方案
java·spring boot·后端
天空属于哈夫克32 小时前
企业微信API常见的错误和解决方案
java·数据库·企业微信
摇滚侠3 小时前
VMvare 虚拟机 Oracle19c 安装步骤,远程连接 Oracle19c,百度网盘安装包
java·oracle
梁萌3 小时前
idea报错找不到XX包的解决方法
java·intellij-idea·启动报错·缺少包
Agent产品评测局3 小时前
生产排期与MES/ERP系统打通,实操方法详解 —— 2026企业级智能体自动化选型与实战指南
java·运维·人工智能·ai·chatgpt·自动化
阿丰资源3 小时前
基于Spring Boot的电影城管理系统(直接运行)
java·spring boot·后端
呱牛do it3 小时前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 8)
java