一、RedisTemplate与StringRedisTemplate
二、Redis的五大数据类型
String
List
Hash
Set
SortedSet
首先想要在SpringBoot中操作Redis数据库需要先在pom.xml中导入坐标/引入依赖
<dependency>
<groupId>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类型的field和value的映射表,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
}