Redis实战--SpringBoot中对Redis数据类型String的基本操作示例

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis实战--SpringBoot中对Redis数据类型String的基本操作示例
该文章是接上一篇文章《Redis整合SpringBoot示例》的后续,操作用例代码比较多,这里展示核心代码所占篇幅很多,所以单独抽出来写

String类型在SpringBoot中的使用代码如下

方法对应的redis基本操作都比较简单,这里不做详细解释,每一个方法都有对应的注释。
package com.example.echo.redis;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.IntStream;

/**
 * @author XLecho
 * Date 2019/11/9 0009
 * Time 10:28
 */
@RunWith(SpringRunner.class)
@SpringBootTest
public class RedisTypeStringUseTest {

    @Autowired
    private RedisTemplate<String, String> redisTemplate;

    /**
     * 存入String类型
     */
    @Test
    public void testSetString() {
        redisTemplate.opsForValue().set("testString", "testString");
        System.out.println(redisTemplate.opsForValue().get("testString"));
    }

    /**
     * 获取存入的String类型
     */
    @Test
    public void testGetString() {
        String string = redisTemplate.opsForValue().get("testString");
        System.out.println(string);
    }

    /**
     * 删除存入的String类型
     */
    @Test
    public void testDelString() {
        redisTemplate.delete("testString");
        System.out.println(redisTemplate.opsForValue().get("testString"));
    }

    /**
     * 对存入的值进行incr递增
     */
    @Test
    public void testIncrString() {
        redisTemplate.opsForValue().set("value", "10");
        redisTemplate.opsForValue().increment("value", 1.1);
        System.out.println(redisTemplate.opsForValue().get("value"));
    }

    /**
     * 对存入的值进行decr递减
     */
    @Test
    public void testDecrString() {
        redisTemplate.opsForValue().set("value", "10");
        redisTemplate.opsForValue().increment("value", -1);
        System.out.println(redisTemplate.opsForValue().get("value"));
    }

    /**
     * 对存入的值进行append拼接
     */
    @Test
    public void testAppendString() {
        redisTemplate.opsForValue().set("value", "string");
        redisTemplate.opsForValue().append("value", "s");
        System.out.println(redisTemplate.opsForValue().get("value"));
    }

    /**
     * 获取指定key对应的索引位置的字符
     */
    @Test
    public void testGetRangeString() {
        redisTemplate.opsForValue().set("value", "abcdefgh");
        String value = redisTemplate.opsForValue().get("value", 1, 5);
        System.out.println(value);
    }

    /**
     * 在指定key对应的索引位置后面添加字符666
     * 注意:该方法会从指定索引后面添加666,但是如果指定索引后面刚好有还有3个字符,那么那3个字符会被替换
     */
    @Test
    public void testSetRangeString() {
        redisTemplate.opsForValue().set("value", "666", 2);
        System.out.println(redisTemplate.opsForValue().get("value"));
    }

    /**
     * 获取指定key的长度
     */
    @Test
    public void testStrlenString() {
        System.out.println(redisTemplate.opsForValue().size("value"));
    }

    /**
     * 同时set多个key
     */
    @Test
    public void testMsetString() {
        Map<String, String> map = new HashMap<>();
        map.put("a", "1");
        map.put("b", "2");
        redisTemplate.opsForValue().multiSet(map);
        System.out.println(redisTemplate.opsForValue().get("a"));
        System.out.println(redisTemplate.opsForValue().get("b"));
    }

    /**
     * 同时get多个值
     */
    @Test
    public void testMgetString() {
        List<String> list = Arrays.asList("a", "b");
        System.out.println(redisTemplate.opsForValue().multiGet(list));
    }

    /**
     * setnx的使用
     */
    @Test
    public void testSetnxString() {
        // 使用循环插入多次,校验存在的时候是否能够插入
        IntStream.range(0, 10).forEach(it -> {
            Boolean email = redisTemplate.opsForValue().setIfAbsent("email", "xl_echo@163.com");
            System.out.println(email);
        });
    }
}

项目源码地址:https://coding.net/u/xlsorry/p/SpringBootRedis/git

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
3月前
|
NoSQL 安全 测试技术
Redis游戏积分排行榜项目中通义灵码的应用实战
Redis游戏积分排行榜项目中通义灵码的应用实战
89 4
|
2月前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
180 85
|
2月前
|
存储 NoSQL Redis
redis常见数据类型
Redis 是一种基于内存的键值存储数据库,支持字符串、哈希表、列表、集合及有序集合等多种数据类型,每种类型均有特定用途与适用场景,提供丰富的命令操作,适用于高速数据访问与处理。
56 5
|
3月前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
56 1
|
4月前
|
NoSQL 关系型数据库 MySQL
MySQL与Redis协同作战:优化百万数据查询的实战经验
【10月更文挑战第13天】 在处理大规模数据集时,传统的关系型数据库如MySQL可能会遇到性能瓶颈。为了提升数据处理的效率,我们可以结合使用MySQL和Redis,利用两者的优势来优化数据查询。本文将分享一次实战经验,探讨如何通过MySQL与Redis的协同工作来优化百万级数据统计。
165 5
|
4月前
|
NoSQL Redis
Redis 字符串(String)
10月更文挑战第16天
60 4
|
4月前
|
缓存 NoSQL Java
Spring Boot与Redis:整合与实战
【10月更文挑战第15天】本文介绍了如何在Spring Boot项目中整合Redis,通过一个电商商品推荐系统的案例,详细展示了从添加依赖、配置连接信息到创建配置类的具体步骤。实战部分演示了如何利用Redis缓存提高系统响应速度,减少数据库访问压力,从而提升用户体验。
220 2
|
4月前
|
存储 消息中间件 NoSQL
Redis 数据类型
10月更文挑战第15天
57 1
|
4月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
40 3
|
5月前
|
缓存 NoSQL 应用服务中间件
Redis实战篇
Redis实战篇