一、RedisTemplate与StringRedisTemplate

二、Redis的五大数据类型

String

List 

Hash 

Set

SortedSet


首先想要在SpringBoot中操作Redis数据库需要先在pom.xml导入坐标/引入依赖

<dependency&gt;
    <groupId&gt;org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

并且在application.yml配置操作redis

spring:
  redis:
    host: localhost
    #password:我是没配置密码的
    port: 6379
    database: 6 #操作的是6号数据库
    pool:
      max-active: 8 #最大连接max-wait: -1 #连接池最大阻塞等待时间 -1表示无限
      max-idle: 4 #连接池中的最大空闲连接
      min-idle: 0 #连接池中的最小空闲连接

一、RedisTemplate与StringRedisTemplate

其次我要先声明关于RedisTemplate类与StringRedisTemplate类之间的关系。 我们可以发现这个StringRedisTemplate是继承RedisTemplate的。当我们直接使用RedisTemplate这个类去操作Redis的话,会导致存放进去的Key名字序列化。如以下代码

如果我们使用StringRedisTemplate这个类去存放数据可以在Redis中看到我们的Key。当然,也可以使用实现序列化接口将这个存放key序列化修改,但我觉得没差。所以这篇文章我会使用StringRedisTemplate这个类在存放数据

具体在StringRedisTemplate中操作Redis的五种基本类型如下

操作字符串是使用opsForValue()方法

操作hash是使用opsForHash()方法

操作list是使用opsForList()方法

操作set是使用opsForSet()方法

操作有序set即sortedSet是使用opsForZSet()方法

二、Redis的五大数据类型

String

@SpringBootTest
public class SpringDataRedis {
    @Autowired
    private StringRedisTemplate redisTemplate;

    /**
     * 测试Redis的String数据结构
     */
    @Test
    void testRedisString(){
        ValueOperations<String, String> valueOperations = redisTemplate.opsForValue();

        //存入值以及获取值(set、get)
        valueOperations.set("StringKey1","张三");
        String key1 = valueOperations.get("StringKey1");
        System.out.println(key1);//张三

        //获取指定字符串的长度
        Long key1Length = valueOperations.size("StringKey1");
        System.out.println(key1Length);//6

        //存入数据设置缓存时间 TimeUnit.SECONDS 单位:秒
        valueOperations.set("StringKey2","李四",10l, TimeUnit.SECONDS);

        //如果不存在(因为key不能重复)则插入成功返回true 反之返回false
        Boolean a = valueOperations.setIfAbsent("StringKey1", "张三");
        Boolean b = valueOperations.setIfAbsent("StringKey1", "王五");
        System.out.println(a);//false
        System.out.println(b);//false

        //删除指定key 成功返回true 否则false
        Boolean c = valueOperations.getOperations().delete("StringKey1");
        System.out.println(c);//true
    }
}

List 

Redis List简单字符列表,按照插入顺序排序

    /**
     * 测试Redis的List数据结构
     */
    @Test
    void testRedisList(){
        ListOperations<String, String> listOperations = redisTemplate.opsForList();

        //在变量左边添加元素值 如果key不存在新建 添加成功返回添加后的总个数
        Long leftPush = listOperations.leftPush("ListKey1", "ListValue1");
        System.out.println(leftPush);//1

        //向左边批量添加参数元素 如果key不存在新建 添加成功返回添加后的总个数
        Long leftPushAll = listOperations.leftPushAll("ListKey1", "ListValue2", "ListValue3");
        System.out.println(leftPushAll);//3

        //删除指定集合 返回true删除成功
        Boolean listKey1 = listOperations.getOperations().delete("ListKey1");
        System.out.println(listKey1);//true

        //向右边批量)添加元素
        listOperations.rightPush("ListKey2", "Value1");
        listOperations.rightPushAll("ListKey2", "ListValue2", "ListValue3");

        //获取指定区间的所有值
        List<String> list = listOperations.range("ListKey2", 0, -1);
        System.out.println(list);//[Value1, ListValue2, ListValue3]

        //将集合最右边弹出元素并返回值
        String a = listOperations.rightPop("ListKey2");
        System.out.println(a);//ListValue3
        //将集合左边弹出元素并返回值
        String b = listOperations.leftPop("ListKey2");
        System.out.println(b);//ListValue2
    }

Hash 

Redis Hash一个String类型fieldvalue的映射表,hash特别适用于存储对象

    /**
     * 测试Redis的Hash数据结构
     */
    @Test
    void testRedisHash(){
        HashOperations<String, Object, Object> hashOperations = redisTemplate.opsForHash();

        //向key中添加kv键值hashOperations.put("Key","field","value");

        //以kv键值对形式存到key中
        Map<String,String> map = new HashMap<>();
        map.put("field1","value1");
        map.put("field2","value2");
        hashOperations.putAll("Key",map);

        //获取key中所有的HashKey
        Set<Object> redisHashKey = hashOperations.keys("Key");
        System.out.println(redisHashKey);//[field,field1,field2]

        //获取key中的所有的Value值
        List<Object> redisHashValues = hashOperations.values("Key");
        System.out.println(redisHashValues);//[value,value1,value2]

        //获取key中所有的键值对
        Map<Object, Object> redisHashMap = hashOperations.entries("Key");
        System.out.println(redisHashMap);//{field=value,field1=value1,field2=value2}

        //获取key中指定HashKey的value值
        Object o = hashOperations.get("Key", "field");
        System.out.println(o);//value

        //获取key中所有HashKey的个数
        Long HashKeySize = hashOperations.size("Key");
        System.out.println(HashKeySize);//3

        //根据key去删除HashMap根据HashKey 返回删除成功后的数量
        Long a = hashOperations.delete("Key","field1","field2");
        System.out.println(a);//2
    }

Set

Redis Set是String类型的无序集合集合成员唯一的,这就意味着集合中不能出现重复的数据

    /**
     * 测试Redis的Set数据机构
     */
    @Test
    void testRedisSet(){
        SetOperations<String, String> setOperations = redisTemplate.opsForSet();

        //将元素添加到名为names的集合中
        setOperations.add("names","张三","李四","王五");

        //随机获取集合内的某个元素
        String names = setOperations.randomMember("names");
        System.out.println(names);

        //获取集合内索引下标为1的值
        List<String> namesList = setOperations.randomMembers("names", 1);
        System.out.println(namesList);//[李四]

        //获取集合内的元素个数
        Long nameLength = setOperations.size("names");
        System.out.println(nameLength);//3

        //判断集合内是否有该元素
        Boolean b1 = setOperations.isMember("names", "张三");
        Boolean b2 = setOperations.isMember("names", "小七");
        System.out.println(b1);//true
        System.out.println(b2);//false

        //删除集合内的元素 可以删除单个或者多个
        Long remove = setOperations.remove("names", "王五");
        System.out.println(setOperations.size("names"));//2

        //再次创建一个集合
        setOperations.add("namesTwo","阿三","李四","五五","赵六");

        //获取两个集合的差集(不同的元素)
        Set<String> difference = redisTemplate.opsForSet().difference("names", "namesTwo");
        System.out.println(difference);//[张三]

        //获取两个集合的相同集合元素
        Set<String> intersect = redisTemplate.opsForSet().intersect("names", "namesTwo");
        System.out.println(intersect);//[李四]

        //获取两个集合的并集(集合的全部元素)
        Set<String> union = redisTemplate.opsForSet().union("names", "namesTwo");
        System.out.println(union);//[赵六, 五五, 李四, 阿三, 张三]
    }

SortedSet

Redis SortedSet有序集合是String类型元素的集合,且不允许重复的成员,每个元素都会关联一个double类型的分数(score)。Redis中正式通过分数来为集合中的成员进行从小到大排序有序集合的成员是唯一的。但分数却可以重复

    /**
     * 测试Redis的SortedSet数据结构
     */
    @Test
    void testRedisSortedSet(){
        ZSetOperations<String,String> zSetOperations = redisTemplate.opsForZSet();

        //第一种使用SortedSet集合添加元素的方法 添加成功与否并且判断返回布尔值
        Boolean add = zSetOperations.add("zSet", "a", 2.5);
        System.out.println(add);//true

        //第二种添加元素的方法需要传入key以及一个Set<TypedTuple<String>>
        ZSetOperations.TypedTuple<String> typedTuple1 = new DefaultTypedTuple<>("b",0.1);
        ZSetOperations.TypedTuple<String> typedTuple2 = new DefaultTypedTuple<>("c",3.0);
        Set<ZSetOperations.TypedTuple<String>> set = new HashSet();
        set.add(typedTuple1);
        set.add(typedTuple2);
        Long zSet = zSetOperations.add("zSet", set);
        System.out.println(zSet);//2

        //获取其集合内的元素个数
        Long size = zSetOperations.size("zSet");
        System.out.println(size);//3

        //获取区间内的值 0到-1表示全部值
        //因为是有序Set 所以按照升序排序:b为0.1 a为2.5 c为3.0
        Set<String> zSetRange = zSetOperations.range("zSet", 0,-1);
        System.out.println(zSetRange);//[b, a, c]

        //获取指定大小内的值
        Set<String> zSetRangeByScore = zSetOperations.rangeByScore("zSet", 2, 3);
        System.out.println(zSetRangeByScore);//[a,c]

        //返回集合中值在2-3的元素个数
        Long zSetCount = zSetOperations.count("zSet", 2, 3);
        System.out.println(zSetCount);//2

        //获得元素的下标
        Long rank = zSetOperations.rank("zSet", "b");
        System.out.println(rank);//0

        //获得元素的值
        Double score = zSetOperations.score("zSet", "b");
        System.out.println(score);//0.1

        //修改元素的分值(原先的值加上后面的值)
        //此时集合内的元素升序排序为:b为0.1,c为3.0,a为2.5 + 3.5 = 6.0
        Double d = zSetOperations.incrementScore("zSet", "a", 3.5);
        System.out.println(d);//6.0

        //根据分值移除区间元素 返回删除的数量
        //此时删除的是b元素 那么集合内剩下:c为3.0,a为6.0
        Long removeRangeByScore =zSetOperations.removeRangeByScore("zSet", 0, 1);
        System.out.println(removeRangeByScore);//1

        //将区间内的元素进行反转并且返回集合
        Set<String> reverseRange = zSetOperations.reverseRange("zSet", 0, 1);
        System.out.println(reverseRange);//[a, c]

        //批量移除元素根据元素值 返回删除的元素数量
        Long remove = zSetOperations.remove("zSet", "a", "b");
        System.out.println(remove);//1
    }

原文地址:https://blog.csdn.net/m0_65563175/article/details/128376311

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_21074.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注