使用RedisTemplate对Redis的常用操作

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis是一个NoSQL(非关系型数据库)数据库之一,key-value存储系统或者说是一个缓存键值对数据库

01前言


Redis是一个NoSQL(非关系型数据库)数据库之一,key-value存储系统或者说是一个缓存键值对数据库,具有如下特性:

  • 基于内存运行,性能高效
  • 支持分布式,理论上可以无限扩展
  • key-value存储系统
  • 开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API

主要应用场景包括:缓存系统、计数器、消息队列系统、排行榜、社交网络和实时系统、分布式锁和发布/订阅消息等。而在程序中,对Redis的常用操作有一个专门用于操作Redis的模板类(或API),它就是RedisTemplate。

02Redis的数据结构


Redis可以存储键与5种不同数据结构类型之间的映射,这5种数据结构类型分别为String(字符串)、List(列表)、Set(集合)、Hash(散列)和 Zset(有序集合)。

下面来对这5种数据结构类型作简单的介绍:

结构类型 结构存储的值 结构的读写能力
String 字符串、整数或者浮点数 对整个字符串或者字符串的其中一部分执行操作;对象和浮点数执行自增(increment)或者自减(decrement)
List 数组链表,链表上的每个节点都包含了一个元素 从链表的两端推入或者弹出元素;根据偏移量对链表进行修剪(trim);读取单个或者多个元素;根据值来查找或者移除元素
Set 包含元素的无序收集器(unorderedcollection),并且被包含的每个元素都是独一无二的、各不相同 添加、获取、移除单个元素;检查一个元素是否存在于某个集合中;计算交集、并集、差集;从集合里卖弄随机获取元素
Hash 包含键值对的无序散列表 添加、获取、移除单个键值对;获取所有键值对
Zset 字符串成员(member)与浮点数分值(score)之间的有序映射,元素的排列顺序由分值的大小决定 添加、获取、删除单个元素;根据分值范围(range)或者成员来获取元素

RedisTemplate位于spring-data-redis包下:

package org.springframework.data.redis.core;
public class RedisTemplate<K, V> extends org.springframework.data.redis.core.RedisAccessor implements org.springframework.data.redis.core.RedisOperations<K, V>

继承了RedisAccessor类,实现了RedisOperations泛型键值对接口。

使用注解即可引用RedisTemplate:

@Autowiredprivate RedisTemplate<String,String> redisTemplate;

03种数据结构的操作


redisTemplate使用如下几种方法分别针对5种数据结构进行操作:

  • redisTemplate.opsForValue();//操作字符串
  • redisTemplate.opsForHash();//操作hash
  • redisTemplate.opsForList();//操作list
  • redisTemplate.opsForSet();//操作set
  • redisTemplate.opsForZSet();//操作有序set

3.1 String字符串操作

//设置key和value值redisTemplate.opsForValue().set("key","value");//通过key获取value值String result = redisTemplate.opsForValue().get("key").toString();

3.2 list数组操作

//list数组对象和添加数组值List<String> list = new ArrayList<String>();  list.add("a1");  list.add("a2");  list.add("a3");  
//用redisTemplate模板类把list数组集合添加进RedisredisTemplate.opsForList().leftPush("listkey",list);  
//用redisTemplate模板类从Redis中根据key获取list集合List<String> resultList = (List<String>)redisTemplate.opsForList().leftPop("listkey");

3.3 Hash结构,map操作

//定义Map集合和类型Map<String,String> map = new HashMap<String,String>();  map.put("key1","value1");  map.put("key2","value2");  map.put("key3","value3");  
//用redis模板类把map设置到redis中redisTemplate.opsForHash().putAll("map",map);  Map<String,String> resultMap = redisTemplate.opsForHash().entries("map");  List<String> reslutMapList = redisTemplate.opsForHash().values("map");  Set<String> resultMapSet = redisTemplate.opsForHash().keys("map");  String value = (String)redisTemplate.opsForHash().get("map","key1");

3.4 Set集合操作

//定义一个set集合并设置集合值SetOperations<String, String> set = redisTemplate.opsForSet();set.add("set1","22");  set.add("set1","33");  set.add("set1","44");  //通过key获取set集合中的对象值Set<String> resultSet = redisTemplate.opsForSet().members("set1");

04总结


以上就是Redis的几种常用数据结构和操作。很多互联网大厂都有用Redis在各种业务场景进行使用,如今分布式流行的趋势,Redis更是举足轻重不可不掌握的一个技术;除了Redis,还有MemCache、Cassadra和Mongo等NoSQL。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
6月前
|
JSON NoSQL Java
Redis入门到通关之Java客户端SpringDataRedis(RedisTemplate)
Redis入门到通关之Java客户端SpringDataRedis(RedisTemplate)
254 0
|
6月前
|
缓存 NoSQL Java
RedisTemplate操作Redis,这一篇文章就够了
redis是一款开源的Key-Value数据库,运行在内存中,由C语言编写。企业开发通常采用Redis来实现缓存。同类的产品还有memcache 、memcached 等。
784 1
|
2月前
|
JSON NoSQL Java
redis的java客户端的使用(Jedis、SpringDataRedis、SpringBoot整合redis、redisTemplate序列化及stringRedisTemplate序列化)
这篇文章介绍了在Java中使用Redis客户端的几种方法,包括Jedis、SpringDataRedis和SpringBoot整合Redis的操作。文章详细解释了Jedis的基本使用步骤,Jedis连接池的创建和使用,以及在SpringBoot项目中如何配置和使用RedisTemplate和StringRedisTemplate。此外,还探讨了RedisTemplate序列化的两种实践方案,包括默认的JDK序列化和自定义的JSON序列化,以及StringRedisTemplate的使用,它要求键和值都必须是String类型。
redis的java客户端的使用(Jedis、SpringDataRedis、SpringBoot整合redis、redisTemplate序列化及stringRedisTemplate序列化)
|
5月前
|
监控 NoSQL Java
在 Spring Boot 中实现 Redis 的发布/订阅功能可以通过 RedisTemplate 和消息监听器来完成
在 Spring Boot 中实现 Redis 的发布/订阅功能可以通过 RedisTemplate 和消息监听器来完成
270 1
|
5月前
|
存储 监控 NoSQL
Redis系列学习文章分享---第十二篇(搭建哨兵集群+RedisTemplate连接哨兵+搭建分片集群+-散列插槽+集群伸缩 +故障转移+RedisTemplate访问分片集群)
Redis系列学习文章分享---第十二篇(搭建哨兵集群+RedisTemplate连接哨兵+搭建分片集群+-散列插槽+集群伸缩 +故障转移+RedisTemplate访问分片集群)
241 0
|
5月前
|
存储 NoSQL Java
Redis系列学习文章分享---第二篇(Redis快速入门之Java客户端--Jedis+连接池+SpringDataRedis+RedisTemplate+RedisSerializer+Hash)
Redis系列学习文章分享---第二篇(Redis快速入门之Java客户端--Jedis+连接池+SpringDataRedis+RedisTemplate+RedisSerializer+Hash)
260 0
|
6月前
|
NoSQL Java Redis
SpringBoot中操作RedisTemplate获取redis中以某些字符串为前缀的KEY列表
SpringBoot中操作RedisTemplate获取redis中以某些字符串为前缀的KEY列表
178 0
|
6月前
|
存储 JSON NoSQL
[Redis]——RedisTemplate的两种序列化方式
[Redis]——RedisTemplate的两种序列化方式
323 0
|
6月前
|
NoSQL Unix Redis
Redis - 五种数据类型与常用操作详解-1
Redis - 五种数据类型与常用操作详解-1
50 0
|
NoSQL Redis
RedisTemplate执行lua脚本在Redis集群模式下报错EvalSha is not supported in cluster environment.
RedisTemplate执行lua脚本在Redis集群模式下报错EvalSha is not supported in cluster environment.
296 0
下一篇
无影云桌面