目录
- 一、在java中操作Redis
-
- 1、Redis的Java客户端
- [2、Spring Data Redis使用方式](#2、Spring Data Redis使用方式)
- [二、Spring Data Redis使用方式](#二、Spring Data Redis使用方式)
一、在java中操作Redis

1、Redis的Java客户端
Redis 的 Java 客户端很多,常用的几种:
Jedis
Lettuce
Spring Data Redis
Spring Data Redis 是 Spring 的一部分,对 Redis 底层开发包进行了高度封装。
在 Spring 项目中,可以使用Spring Data Redis来简化操作。
2、Spring Data Redis使用方式
操作步骤:
1、导入Spring Data Redis 的maven坐标
2、配置Redis数据源
3、编写配置类,创建RedisTemplate对象
4、通过RedisTemplate对象操作Redis
Spring Data Redis的maven坐标如下:
xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
配置Redis数据源:
redis数据库与mysql数据库需要同级进行配置,两种数据库互不干扰。

xml
redis:
port: 6379
host: localhost
database: 0
password:
编写配置类,创建RedisTemplate对象:
java
@Configuration
@Slf4j
public class RedisTemplateConfig {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){
log.info("开始创建RedisTemplate对象");
RedisTemplate redisTemplate = new RedisTemplate();
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new StringRedisSerializer());
redisTemplate.setConnectionFactory(redisConnectionFactory);
return redisTemplate;
}
}
通过RedisTemplate对象操作Redis
java
package com.sky;
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.RedisTemplate;
@SpringBootTest
public class RedisTemplateTest {
@Autowired
private RedisTemplate redisTemplate;
@Test
public void testRedis(){
System.out.println(redisTemplate);
}
}
二、Spring Data Redis使用方式
RedisTemplate 针对大量api进行了归类封装,将同一数据类型的操作封装为对应的Operation接口,具体分类如下:
ValueOperations:string数据操作
SetOperations:set类型数据操作
ZSetOperations:zset类型数据操作
HashOperations:hash类型的数据操作
ListOperations:list类型的数据操作
1、ValueOperations使用
java
@Test
public void testRedis(){
ValueOperations valueOperations = redisTemplate.opsForValue();
valueOperations.set("hello","world");
valueOperations.set("hello1","world1", 60, TimeUnit.MINUTES);
String o =(String) valueOperations.get("hello");
System.out.println(o);
valueOperations.setIfAbsent("hello2","world2");
}
ValueOperations valueOperations = redisTemplate.opsForValue();获得redis操作string数据类型的对象。
java
valueOperations.set("hello","world"); 对应 redis中的set方法和setex方法
java
String o =(String) valueOperations.get("hello"); 对应redis中的get方法
java
valueOperations.setIfAbsent("hello2","world2"); 对应redis中的setnx方法
2、SetOperations使用
java
@Test
public void testRedis2(){
SetOperations setOperations = redisTemplate.opsForSet();
setOperations.add("set1","1","2","3","4");
Set set1 = setOperations.members("set1");
setOperations.remove("set1","1");
Long set11 = setOperations.size("set1");
System.out.println(set1);
setOperations.add("set2","4","5","6","7");
Set intersect = setOperations.intersect("set1", "set2");
System.out.println(intersect);
Set union = setOperations.union("set1", "set2");
System.out.println(union);
}
SetOperations setOperations = redisTemplate.opsForSet();获取redis操作集合的对象。
setOperations.add("set1","1","2","3","4"); 对应 sadd key value1 value2
Set set1 = setOperations.members("set1");获取集合中所有的元素对应smembers key
Long set11 = setOperations.size("set1");获取集合的大小与scard key对应
Set intersect = setOperations.intersect("set1", "set2");获取集合之间的交集与sinter key1 key2
Set union = setOperations.union("set1", "set2");获取集合之间的并集与sunion key1 key2对应
setOperations.remove("set1","1");删除集合中的某一个数值与srem key value对应
3、ZSetOperations使用
css
@Test
public void testRedis3(){
ZSetOperations zSetOperations = redisTemplate.opsForZSet();
zSetOperations.add("zset1","1",1);
zSetOperations.add("zset1","2",2);
zSetOperations.add("zset1","3",3);
Set zset1 = zSetOperations.range("zset1", 0, -1);
System.out.println(zset1);
zSetOperations.remove("zset1","1");
zSetOperations.incrementScore("zset1","2",4);
}
ZSetOperations zSetOperations = redisTemplate.opsForZSet();获取redis操作有序集合的对象。
zSetOperations.add("zset1","1",1);有序集合添加数值以及分数与zadd key score value对应。
Set zset1 = zSetOperations.range("zset1", 0, -1);获取有序集合中的数值,与zrange key start end
zSetOperations.remove("zset1","1"); 有序数组删除操作,与zrem key value对应
zSetOperations.incrementScore("zset1","2",4);为有序数组中某个值添加分数,与zincreby key score value对应。
4、HashOperations使用
java
@Test
public void testRedis4(){
HashOperations hashOperations = redisTemplate.opsForHash();
hashOperations.put("hash1","name","zhangsan");
hashOperations.put("hash1","age",18);
String o = (String)hashOperations.get("hash1", "name");
Long hash1 = hashOperations.size("hash1");
System.out.println(o);
hashOperations.delete("hash1","name");
hashOperations.keys("hash1");
hashOperations.values("hash1");
}
HashOperations hashOperations = redisTemplate.opsForHash();是获取redis操作哈希的对象。
hashOperations.put("hash1","name","zhangsan");添加哈希值与hset key filed value对应
String o = (String)hashOperations.get("hash1", "name");获取哈希中的值与hget key filed对应
hashOperations.delete("hash1","name");删除哈希中对应的值与hdel key filed对应
hashOperations.keys("hash1");获取哈希中所有的键与hkeys key对应
hashOperations.values("hash1");获取哈希中所有的值与hvals key对应
5、ListOperations使用
java
@Test
public void testRedis5(){
ListOperations listOperations = redisTemplate.opsForList();
listOperations.leftPush("list1","1");
listOperations.leftPush("list1","2");
listOperations.leftPush("list1","3");
listOperations.rightPop("list1");
List list1 = listOperations.range("list1", 0, -1);
System.out.println(list1);
listOperations.remove("list1",1,"2");
listOperations.leftPush("list1","4");
Long list11 = listOperations.size("list1");
System.out.println(list11);
}
ListOperations listOperations = redisTemplate.opsForList();获取redis操作list列表的对象。
listOperations.leftPush("list1","1");添加列表值与 lpush key value对应。
listOperations.rightPop("list1");删除第一个添加的值与rpop key
Long list11 = listOperations.size("list1");获取列表的大小与llen key对应