redis的java基本操作(二)

一、SpringDataRedis简介

1、Redis

redis是一款开源的Key-Value数据库,运行在内存中,由C语言编写。企业开发通常采用Redis来实现缓存。同类的产品还有memcache 、memcached 等。

2、Jedis

Jedis是Redis官方推出的一款面向Java的客户端,提供了很多接口供Java语言调用。可以在Redis官网下载,当然还有一些开源爱好者提供的客户端,如Jredis、SRP等等,推荐使用Jedis。

3、Spring Data Redis

Spring-data-redis是spring大家族的一部分,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,支持发布订阅,并对spring 3.1 cache进行了实现。
spring-data-redis针对jedis提供了如下功能:

  1. 连接池自动管理,提供了一个高度封装的“RedisTemplate”类
  2. 针对jedis客户端中大量api进行了归类封装,将同一类型操作封装为operation接口
  • ValueOperations:简单K-V操作
  • SetOperations:set类型数据操作
  • ZSetOperations:zset类型数据操作
  • HashOperations:针对map类型的数据操作
  • ListOperations:针对list类型的数据操作
  1. 提供了对key的“bound”(绑定)便捷化操作API,可以通过bound封装指定的key,然后进行一系列的操作而无须“显式”的再次指定Key,即BoundKeyOperations:(一般不这么用,太复杂了)
  • BoundValueOperations
  • BoundSetOperations
  • BoundListOperations
  • BoundSetOperations
  • BoundHashOperations
  1. 将事务操作封装,有容器控制。
  2. 针对数据的“序列化/反序列化”,提供了多种可选择策略(RedisSerializer)

**JdkSerializationRedisSerializer:**POJO对象的存取场景,使用JDK本身序列化机制,将pojo类通过ObjectInputStream/ObjectOutputStream进行序列化操作,最终redis-server中将存储字节序列。是目前最常用的序列化策略。

**StringRedisSerializer:**Key或者value为字符串的场景,根据指定的charset对数据的字节序列编码成string,是“new String(bytes, charset)”和“string.getBytes(charset)”的直接封装。是最轻量级和高效的策略。

**JacksonJsonRedisSerializer:**jackson-json工具提供了javabean与json之间的转换能力,可以将pojo实例序列化成json格式存储在redis中,也可以将json格式的数据转换成pojo实例。因为jackson工具在序列化和反序列化时,需要明确指定Class类型,因此此策略封装起来稍微复杂。【需要jackson-mapper-asl工具支持】

二、RedisTemplate中API使用

1、pom.xml依赖

<!--Redis-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
12345

2、配置文件

# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器地址
spring.redis.host=127.0.0.1
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器连接密码(默认为空)
spring.redis.password=
# 连接池最大连接数(使用负值表示没有限制)
spring.redis.jedis.pool.max-active=8
# 连接池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.jedis.pool.max-wait=-1ms
# 连接池中的最大空闲连接
spring.redis.jedis.pool.max-idle=8
# 连接池中的最小空闲连接
spring.redis.jedis.pool.min-idle=0
# 连接超时时间(毫秒)
spring.redis.timeout=5000ms

3、RedisTemplate的直接方法

首先使用@Autowired注入RedisTemplate。

一般我会自己写一个了,RedisClient封装方法

public class RedisClient{
    @Autowired
	private RedisTemplate redisTemplate;
    
    //一系列的redis操作
    ......
}

三、redis的五大类型操作

1、ValueOperations:简单K-V操作

写入缓存

ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();
operations.set(key, value);

新增缓存

operations.increment(key, value);

设置过期时间

redisTemplate.expire(key, expireTime, TimeUnit.SECONDS);

批量删除

Set<Serializable> keys = redisTemplate.keys(pattern);
if (keys.size() > 0)   redisTemplate.delete(keys);

判断是否存在

redisTemplate.hasKey(key);

获取缓存

operations.get(key);

2、HashOperations:针对map类型的数据操作

哈希添加数据,HashOperations<String, Object, Object>为什么这里是三个参数?

首先hash存储也是已<key, value>存储的,它是一个字符串类型的键值对列表,其中value是键值对<key,value>

如果不能理解的参考,Redis的hash用法

HashOperations<String, Object, Object> hash = redisTemplate.opsForHash();
hash.put(key, hashKey, value);

获取key数据大小

hash.size(key);

哈希获取单个数据

hash.get(key, hashKey);

获取多个value

Collection< Object> hashKeys
List list = hash.multiGet(key, hashKeys);

获取多个键值对

Set<Object> set = hash.keys(key);

删除数据

hash.delete(key, hashKeys);

3、ListOperations:针对list类型的数据操作

列表添加

ListOperations<String, Object> list = redisTemplate.opsForList();list.rightPush(k, v);

批量添加,这个有个概念就是leftpush、rightpushh

不明白的去这个博客看看

List<? extends Object> values
ListOperations<String, Object> list = redisTemplate.opsForList();
list.rightPushAll(key, values);

列表获取数据

ListOperations<String, List<? extends Object>> list = redisTemplate.opsForList();return list.range(k, l, l1);

2、SetOperations:set类型数据操作

集合添加缓存

SetOperations<String, Object> set = redisTemplate.opsForSet();
set.add(key, value);

集合获取缓存

Set<Object> set = set.members(key);

3、ZSetOperations:zset类型数据操作

有序集合存储缓存,下面的这个souce是指定元素的分值。

ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();
zset.add(key, value, scoure);

获取有序集合的数据

ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();
return zset.rangeByScore(key, scoure, scoure1);

删除有序集合中的元素, Object…values可变参数既可以用数组形式,也可以各个实参分别传递。二者都有

Object... values
ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();
zset.remove(key, values);

根据范围删除元素

ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();
return zset.removeRangeByScore(key, minScoure, maxSource);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值