Redis 黑马skyout

sql 复制代码
> localhost connected!
> get name
jack
> setex code 30 1234
OK
> get code
1234
> setnx code1 114514//不可修改
sql 复制代码
> hset 001 name xm
1
> hset 001 age 22
1
> hkeys 001
name
age
> hvals 001
xm
22
sql 复制代码
package com.sky.test;


import org.apache.el.parser.BooleanNode;
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.connection.DataType;
import org.springframework.data.redis.core.*;

import java.util.List;
import java.util.Objects;
import java.util.Set;
import java.util.concurrent.TimeUnit;

@SpringBootTest
public class SpringDataRedisTest {
    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void testRedis(){
        ValueOperations valueOperations = redisTemplate.opsForValue();
        HashOperations hashOperations = redisTemplate.opsForHash();
        ListOperations listOperations = redisTemplate.opsForList();
        SetOperations setOperations = redisTemplate.opsForSet();
        ZSetOperations zSetOperations = redisTemplate.opsForZSet();
    }

    /**
     * 操作字符串类型
     */
    @Test
    public void testString(){
        redisTemplate.opsForValue().set("city","北京");
        Object city = redisTemplate.opsForValue().get("city");
        System.out.println(city);
        redisTemplate.opsForValue().set("code","1234",3, TimeUnit.MINUTES);
        redisTemplate.opsForValue().setIfAbsent("lock","1");
        redisTemplate.opsForValue().setIfAbsent("lock","2");
    }

    /**
     * 操作hash类型
     */
    @Test
    public void testHash(){
        HashOperations hashOperations = redisTemplate.opsForHash();

        hashOperations.put("100","name","tom");
        hashOperations.put("100","age","20");

        String name = (String) hashOperations.get("100","name");
        System.out.println(name);

        Set keys = hashOperations.keys("100");
        System.out.println(keys);

        List values = hashOperations.values("100");
        System.out.println(values);

        hashOperations.delete("100","age");

    }

    /**
     * 操作list类型
     */
    @Test
    public void testList(){
        ListOperations listOperations = redisTemplate.opsForList();

        listOperations.leftPushAll("mylist","a","b","c");
        listOperations.leftPush("mylist","d");

        List mylist = listOperations.range("mylist",0,-1);
        System.out.println(mylist);
        listOperations.rightPop("mylist");
        Long size = listOperations.size("mylist");
        System.out.println(size);
    }
    /**
     * 操作set类型
     */
    //sadd smembers scard sinter sunion srem
    @Test
    public void testSet(){
        SetOperations setOperations = redisTemplate.opsForSet();
        setOperations.add("mySet1","a","b","c");
        setOperations.add("mySet2","a","b","d");

        Set members = setOperations.members("myset1");
        System.out.println(members);

        Long size = setOperations.size("mySet1");
        System.out.println(size);

        Set intersect = setOperations.intersect("mySet1","mySet2");
        System.out.println(intersect);

        Set union = setOperations.union("mySet1","mySet2");
        System.out.println(union);

        setOperations.remove("mySet1","a","b");

    }

    /**
     * 操作zset类型
     */
    @Test
    public void testZSet(){
        ZSetOperations zSetOperations = redisTemplate.opsForZSet();

        zSetOperations.add("myzset", "tom", 10);
        zSetOperations.add("myzset", "jerry", 20);
        zSetOperations.add("myzset", "lucy", 30);

        Set zset1 = zSetOperations.range("myzset",0,-1);
        System.out.println(zset1);
    }

    /**
     * 通用命令
     */
    @Test
    public void testCommon(){
    //keys exists type del
        Set keys = redisTemplate.keys("*");
        System.out.println(keys);

        Boolean name = redisTemplate.hasKey("*");
        Boolean set1 = redisTemplate.hasKey("set1");

        for (Object key : keys){
            DataType type = redisTemplate.type(key);
            System.out.println(type.name());

        }
    }
}
相关推荐
2401_8735878216 分钟前
MySQL——事务管理
数据库·mysql
探索宇宙真理.17 分钟前
SiYuan SQL漏洞 | CVE-2026-29073复现&研究
数据库·经验分享·sql·eureka·安全漏洞·siyuan
2501_9454235418 分钟前
工具、测试与部署
jvm·数据库·python
Oueii18 分钟前
数据分析师的Python工具箱
jvm·数据库·python
我真会写代码18 分钟前
深度解析并发编程锁升级:从偏向锁到重量级锁,底层原理+面试考点全拆解
java·并发编程·
TDengine (老段)21 分钟前
TDengine IDMP 组态面板 —— 工具箱
大数据·数据库·时序数据库·tdengine·涛思数据
Meepo_haha24 分钟前
创建Spring Initializr项目
java·后端·spring
weixin_4219226924 分钟前
使用Scikit-learn进行机器学习模型评估
jvm·数据库·python
会编程的土豆24 分钟前
C++中的 lower_bound 和 upper_bound:一篇讲清楚
java·数据结构·算法