NoSQL之Redis(二)---Java操作Redis存储自定义类型数据

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介:


NoSQL之Redis(二)---Java操作Redis存储自定义类型数据

 


         Redis简介

 

         Redis是一个开源,先进的key-value存储,并用于构建高性能,可扩展的Web应用程序的完美解决方案。

 

         Redis从它的许多竞争继承来的三个主要特点:

  • Redis数据库完全在内存中,使用磁盘仅用于持久性。
  • 相比许多键值数据存储,Redis拥有一套较为丰富的数据类型。
  • Redis可以将数据复制到任意数量的从服务器。

 

         Redis操作

         使用java语言操作redis需要引用jedis的jar包,我用的版本是2.8.0【点击下载】。Redis支持存储的数据类型有String,List,Map,Set,Hash及Zset。

         由于简单的操作Redis的基本类型在网上很容易就找到一堆资料,所以今天笔者主要写如何使用redis存储自定义类型。

         Redis中支持的基本类型String,而且在我试验的过程中发现无论是List还是Map也都只能放String类型的数据。所以如果我们想要存储自定义类型的数据的时候,不可避免的会有两个过程——序列化与反序列化。

 

         代码

//定义需要存储的数据
StudentVo studentVo = newStudentVo();
studentVo.setId(student.getId());
studentVo.setApplyTeacherState(student.getApplyTeacherState());
studentVo.setBornDate(student.getBornDate());
studentVo.setHeadPic(student.getHeadPic());
studentVo.setIntroduce(student.getIntroduce());
studentVo.setIsTeacher(student.getIsTeacher());
studentVo.setRealName(student.getRealName());
studentVo.setNickName(student.getNickName());
studentVo.setPhoNum(student.getPhoNum());
 
jedis = new Jedis("XXX.56. XXX.XXX ", 6379);    //实例化一个新的jedis对象
 
UUID uuid = UUID.randomUUID();
String jSession = uuid.toString();
studentVo.setSessionId(jSession);      //jSession是用户登录过程中产生的唯一标识
jedis.set(jSession.getBytes(),SerializationUtil.serialize(studentVo));    //SerializationUtil负责序列化与反序列化的类
jedis.expire(jSession, 3600);            // 设置过期时间
 
//上面描述的是如何存储自定义类型,下面是如何使用了
//如果登录系统之后,系统访问链接后面都会带着一个UUID作为唯一标识,
//例如:http://www.jrkj.org/itoo-jrkj-homepageset-web/index/63db86a4-12de-443d-bff0-23d4f6ab67c0
 
byte[] bSession= jedis.get(sessionId.getBytes());  //sessionId是用户的唯一标识,
StudentVo student = (StudentVo)SerializationUtil.deserialize(bSession); //通过反序列化就能够获取存储的数据


         序列化与反序列化代码

public classSerializationUtil {
    /**
    * 序列化
    *
    * @param object
    * @return
    */
    publicstatic byte[] serialize(Object object) {
       ObjectOutputStream oos = null;
       ByteArrayOutputStream baos = null;
       try {
           baos = new ByteArrayOutputStream();
           oos = new ObjectOutputStream(baos);
           oos.writeObject(object);
           byte[] bytes = baos.toByteArray();
           return bytes;
       } catch (Exception e) {
       }
       return null;
    }
 
    /**
    * 反序列化
    *
    * @param bytes
    * @return
    */
    publicstatic Object deserialize(byte[] bytes) {
       ByteArrayInputStream bais = null;
       try {
           bais = new ByteArrayInputStream(bytes);
           ObjectInputStream ois = new ObjectInputStream(bais);
           return ois.readObject();
       } catch (Exception e) {
 
       }
       return null;
    }
 
}

         小结

         Jedis操作redis存储定义一类型主要就是一个序列化与反序列化的过程,这个之后你就可以存储任意类型的数据了。不妨自己写个demo试试,如何安装redis之前的博客中已经有介绍,也可以在网上找找相关的教程。

 

         笔者在这里提前祝大家新春快乐,希望新的一年里,大家心想事成、阖家幸福!

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
23天前
|
存储 缓存 NoSQL
【Azure Redis 缓存】关于Azure Cache for Redis 服务在传输和存储键值对(Key/Value)的加密问题
【Azure Redis 缓存】关于Azure Cache for Redis 服务在传输和存储键值对(Key/Value)的加密问题
|
3天前
|
存储 缓存 NoSQL
【Java面试题汇总】Redis篇(2023版)
Redis的数据类型、zset底层实现、持久化策略、分布式锁、缓存穿透、击穿、雪崩的区别、双写一致性、主从同步机制、单线程架构、高可用、缓存淘汰策略、Redis事务是否满足ACID、如何排查Redis中的慢查询
【Java面试题汇总】Redis篇(2023版)
|
15天前
|
Java API 开发者
代码小妙招:用Java轻松获取List交集数据
在Java中获取两个 `List`的交集可以通过 `retainAll`方法和Java 8引入的流操作来实现。使用 `retainAll`方法更为直接,但会修改原始 `List`的内容。而使用流则提供了不修改原始 `List`、更为灵活的处理方式。开发者可以根据具体的需求和场景,选择最适合的方法来实现。了解和掌握这些方法,能够帮助开发者在实际开发中更高效地处理集合相关的问题。
13 1
|
23天前
|
缓存 NoSQL 网络协议
【Azure Redis 缓存】Redisson 连接 Azure Redis出现间歇性 java.net.UnknownHostException 异常
【Azure Redis 缓存】Redisson 连接 Azure Redis出现间歇性 java.net.UnknownHostException 异常
|
25天前
|
监控 Java 开发工具
【事件中心 Azure Event Hub】Event Hub Java SDK的消费端出现不消费某一个分区中数据的情况,出现IdleTimerExpired错误消息记录
【事件中心 Azure Event Hub】Event Hub Java SDK的消费端出现不消费某一个分区中数据的情况,出现IdleTimerExpired错误消息记录
|
25天前
|
存储 Java Apache
|
17天前
|
开发者 Java Spring
【绝技揭秘】掌握Vaadin数据绑定:一键同步Java对象,告别手动数据烦恼,轻松玩转Web应用开发!
【8月更文挑战第31天】Vaadin不仅是一个功能丰富的Java Web应用框架,还提供了强大的数据绑定机制,使开发者能轻松连接UI组件与后端Java对象,简化Web应用开发流程。本文通过创建一个简单的用户信息表单示例,详细介绍了如何使用Vaadin的`Binder`类实现数据绑定,包括字段与模型属性的双向绑定及数据验证。通过这个示例,开发者可以更专注于业务逻辑而非繁琐的数据同步工作,提高开发效率和应用可维护性。
38 0
|
24天前
|
缓存 NoSQL Java
【Azure Redis 缓存】定位Java Spring Boot 使用 Jedis 或 Lettuce 无法连接到 Redis的网络连通性步骤
【Azure Redis 缓存】定位Java Spring Boot 使用 Jedis 或 Lettuce 无法连接到 Redis的网络连通性步骤
|
24天前
|
固态存储 Java 网络安全
【Azure Developer】使用Java SDK代码创建Azure VM (包含设置NSG,及添加数据磁盘SSD)
【Azure Developer】使用Java SDK代码创建Azure VM (包含设置NSG,及添加数据磁盘SSD)
|
25天前
|
存储 安全 Java
在 Java 中如何存储数组列表
【8月更文挑战第23天】
21 0