Redis | 在Java中操作Redis

在Java中操作Redis:

    • 第一步: pom.xml文件中导入maven依赖
    • 第二步: 在application.yml配置文件中 配置Redis数据源
    • 第三步: 编写RedisConfiguration配置类,创建RedisTemplate对象
    • 第四步: 通过RedisTemplate对象操作Redis / Redis中的数据
      • 4.1 操作“字符串String类型”数据
      • 4.2 操作“哈希hash类型的数据”
      • 4.3 操作“列表list类型的数据”
      • 4.4 操作“集合set类型的数据”
      • 4.5 操作“有序集合set类型的数据”
      • 4.6 通用命令“操作数据”

  • ① 在pom.xml文件导入 Spring Data RedisMaven依赖
  • 配置Redis数据源
  • ③ 编写配置类,通过创建RedisTemplate对象。
  • ④ 通过RedisTemplate对象操作Redis。

第一步: pom.xml文件中导入maven依赖

	<!--  Spring-data-redis的依赖  -->  <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency>

第二步: 在application.yml配置文件中 配置Redis数据源

  • 配置Redis数据源类似于配置Mysql数据源。通过Redis数据源能连接到数据库。(注意 : 可在 spring: 这个配置项下进行配置。)

  •   redis:  host: localhostport: 6379password: 123456database: 10    #一般不直接在配置文件中写明确的数据
    
  • 配置项的功能介绍

    host: 表示当前要连接的redis服务的IP地址。
    port: 表示端口号,默认的端口号为6379。
    password: 密码。
    database: 数据库。Redis服务启动之后默认情况下,其在redis服务中会创建好16个库(DB0-DB15)。每个数据库之间的数据是完全隔离的。(如果不配置时Redis默认使用的是DB0

第三步: 编写RedisConfiguration配置类,创建RedisTemplate对象

@Configuration
@Slf4j //记录日志
public class RedisConfiguration {/*** RedisTemplate : Redis模板对象* @param redisConnectionFactory redis连接工厂对象* @return*/@Bean //将该方法返回值的"对象:RedisTemplate"存入到bean容器中,交给Spring容器管理public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {log.info("开始创建Redis模板对象...");// RedisTemplate是Spring Data Redis的一个核心组件,用于在Java中与Redis进行交互RedisTemplate redisTemplate = new RedisTemplate;// 设置Redis的连接工厂对象 (关联RedisConnectionFactory对象)redisTemplate.setConnectionFactory(redisConnectionFactory);//设置redis key的序列化器//设定为: "符串Redis序列化器"redisTemplate.setKeySerializer(new StringRedisSerializer()); return redisTemplate;}
}

第四步: 通过RedisTemplate对象操作Redis / Redis中的数据

4.1 操作“字符串String类型”数据

//用于测试Spring Boot应用程序的注解
@SpringBootTest
public class SpringDataRedisTest { //SpringDataRedis测试类//注入RedisTemplate对象@Autowiredprivate RedisTemplate redisTemplate;/*** 操作String字符串类型的数据*/@Testpublic void testString() {/*操作字符串的命令:set   : 插入字符串get   : 获得字符串setex : 插入字符串的同时,可以设置该字符串的“有效期”setnx : 当设置的key不存在时,才插入字符串*/ValueOperations valueOperations = redisTemplate.opsForValue();//向Redis中设置字符串valueOperations.set("city","北京");//获取字符串String city = (String) valueOperations.get("city");//设置有特定“有效期”的字符串valueOperations.set("code","123456",3, TimeUnit.MINUTES); //有效期三分钟//当设置的key不存在时,才插入字符串valueOperations.setIfAbsent("lock", 1);valueOperations.setIfAbsent("lock", 2);}
}

4.2 操作“哈希hash类型的数据”

//用于测试Spring Boot应用程序的注解,
@SpringBootTest
public class SpringDataRedisTest { //SpringDataRedis测试类//注入RedisTemplate对象@Autowiredprivate RedisTemplate redisTemplate;/*** 操作哈希hash类型的数据*/@Testpublic void testHash() {/*hset  : 将哈希表key中的字段field的值设定为valuehget  : 获取存储在哈希表中指定字段的值hdel  : 删除存储在哈希表中的指定字段hkeys : 获取key对应的“哈希表中所有字段”hvals : 获取key对应的”哈希表中所有值“*/HashOperations hashOperations = redisTemplate.opsForHash();//存储hash类型数据hashOperations.put("100", "name", "tom");hashOperations.put("100", "age", "20");//获取hash类型数据String name = (String) hashOperations.get("100", "name");System.out.println(name);//获取key对应的“哈希表中所有字段”Set keys = hashOperations.keys("100");System.out.println(keys);//获取key对应的”哈希表中所有值“List values = hashOperations.values("100");System.out.println(values);//删除数据hashOperations.delete("100", "age");}
}

4.3 操作“列表list类型的数据”

@SpringBootTest
public class SpringDataRedisTest { //SpringDataRedis测试类//注入RedisTemplate对象@Autowiredprivate RedisTemplate redisTemplate;/*** 操作列表list类型的数据*/@Testpublic void testList() {/*lpush  : 将一个或多个值插入到列表头部(列表左边)rpush  : 将一个或多个值插入到列表尾部(列表右边)lrange : 获取指定范围内的元素lpop   : 移除并获取列表第一个元素rpop   : 移除并获取列表最后一个元素llen   : 获取列表长度*/ListOperations listOperations = redisTemplate.opsForList();//从列表头部插入一个数据listOperations.leftPush("mylist", "a");//从列表头部插入多个数据listOperations.leftPushAll("mylist", "b", "c", "d");//查询列表中指定范围的数据List mylist = listOperations.range("mylist", 0, -1); //查询整个列表所有的元素//移除并获取列表最后一个元素String mylist1 = (String) listOperations.rightPop("mylist");//获得列表长度 (获得列表中元素个数)Long size = listOperations.size("mylist");}
}

4.4 操作“集合set类型的数据”

//用于测试Spring Boot应用程序的注解,
@SpringBootTest
public class SpringDataRedisTest { //SpringDataRedis测试类//注入RedisTemplate对象@Autowiredprivate RedisTemplate redisTemplate;/***  操作集合类型的数据*/@Testpublic void testset() {/*sadd     : 向集合中添加一个或多个成员smembers : 返回(指定key对应)的集合中的所有成员scard    : 返回(指定key对应)的集合中的成员数sinter   : 返回给定所有集合的交集sunion   : 返回所有给定集合的并集srem     : 删除集合中一个或多个成员*/SetOperations setOperations = redisTemplate.opsForSet();//向指定集合中插入元素setOperations.add("set1", "a", "b", "c", "d");setOperations.add("set2", "a", "b", "x", "y");//返回(指定key对应)的集合中的成员数Long size = setOperations.size("set1");//获得 set1 这个key对应的集合中的所有的元素System.out.println(size);//返回给定集合的交集Set intersect = setOperations.intersect("set1", "set2");System.out.println(intersect);//返回所有给定集合的并集Set union = setOperations.union("set1", "set2");//删除集合中一个或多个成员setOperations.remove("set1", "a", "b");}
}

4.5 操作“有序集合set类型的数据”

//用于测试Spring Boot应用程序的注解,
@SpringBootTest
public class SpringDataRedisTest { //SpringDataRedis测试类//注入RedisTemplate对象@Autowiredprivate RedisTemplate redisTemplate;/***  操作“有序集合类型的数据”*/@Testpublic void Zset() {/*zadd    : 向有序集合中插入一个或多个成员zrange  : 通过索引区间返回有序集合中指定区间内的成员zincrby : 有序集合中对指定成员的分数加上增量 incrementzrem    : 移除有序集合中的一个或多个成员*/ZSetOperations zSetOperations = redisTemplate.opsForZSet();//向有序集合中添加元素//三个key一样,表明数据在同一个集合中zSetOperations.add("zset1", "a", 10);zSetOperations.add("zset1", "b", 12);zSetOperations.add("zset1", "c", 9);//查询有序列表中指定区间的数据zSetOperations.range("zset1", 0, -1);//为集合中元素增加值zSetOperations.incrementScore("zset1", "c", 10);//移除结合中元素zSetOperations.remove("zset1", "a", "b");}

4.6 通用命令“操作数据”

//用于测试Spring Boot应用程序的注解,
@SpringBootTest
public class SpringDataRedisTest { //SpringDataRedis测试类//注入RedisTemplate对象@Autowiredprivate RedisTemplate redisTemplate;  /*** 通用命令操作*/public void testComon() {/*keys   : 查找符合给定模式的keyexists : 检查给定key是否存在type   : 返回key所存储的值的类型del    : 该命令用于在key存在时删除key*///获得所有的keySet keys = redisTemplate.keys("*");//检查给定的key是否存在Boolean name = redisTemplate.hasKey("name");Boolean set1 = redisTemplate.hasKey("set1");//返回key所存储的值的类型for (Object key : keys) {DataType type = redisTemplate.type(key);}//删除指定的keyredisTemplate.delete("mylist");}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/115663.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CNN——卷积神经网络

文章目录 多层感知机&#xff08;MLP&#xff0c;Multilayer Perceptron&#xff09;神经网络定义MLP与神经网络的异同相同之处&#xff1a;不同之处&#xff1a;总结 为什么要使用神经网络CNN卷积层&#xff1a;池化层&#xff1a;全连接层&#xff1a; 卷积神经网络的优势pad…

Python---while循环的执行流程 解释

使用Debug调试工具&#xff0c;查看while循环的运行流程 代码 # ① 初始化计数器 i 1 # ② 编写循环条件&#xff08;判断计数器是否达到了100&#xff09; while i < 100:print(f{i 1}、老婆大人&#xff0c;我错了)# ③ 在循环体内部更新计数器i 1 ① 代码都是顺序执行…

基于LSTM的天气预测 - 时间序列预测 计算机竞赛

0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 机器学习大数据分析项目 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-senior/po…

如何为 Elasticsearch 创建自定义连接器

了解如何为 Elasticsearch 创建自定义连接器以简化数据摄取过程。 作者&#xff1a;JEDR BLASZYK Elasticsearch 拥有一个摄取工具库&#xff0c;可以从多个来源获取数据。 但是&#xff0c;有时你的数据源可能与 Elastic 现有的提取工具不兼容。 在这种情况下&#xff0c;你可…

【深蓝学院】手写VIO第7章--VINS初始化和VIO系统--作业

0. 内容 1. T1 1. 下载EuRoc数据集&#xff08;optional&#xff09; 因为作业主要使用Ch2生成的数据&#xff0c;所以这一步也是可选的&#xff0c;但是为了整个系统的bring up&#xff0c;可以先用EuRoc数据集跑起来。 下载EuRoc数据集&#xff0c;SLAM相关数据集链接 2.…

【LeetCode刷题(数据结构与算法)】:数据结构中的常用排序实现数组的升序排列

现在我先将各大排序的动图和思路以及代码呈现给大家 插入排序 直接插入排序是一种简单的插入排序法&#xff0c;其基本思想是&#xff1a; 把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中&#xff0c;直到所有的记录插入完为 止&#xff0c;得到一个…

C++ 火车调度

火车调度 #include<stdio.h> #define MAX 100 typedef struct Q {int data[MAX];int len;int last; }Q_t;Q_t a[MAX]; //MAX个队列 void Init(Q_t* a) {a->len 0; }void En(Q_t* a, int num) {a->last num; //最后进入的值a->data[a->len] num; }void…

c语言练习91:合并两个有序链表

合并两个有序链表 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 代码1&#xff1a; /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/typedef struct ListNode ListNode; struct Li…

Appium+python+unittest搭建UI自动化框架!

阅读本小节&#xff0c;需要读者具备如下前提条件&#xff1a; 1. 掌握一种编程语言基础&#xff0c;如java、python等。 2. 掌握一种单元测试框架&#xff0c;如java语言的testng框架、python的unittest框架。 3. 掌握目前主流的UI测试框架&#xff0c;移动端APP测试框架Appiu…

LVS+DR部署

LVS-DR的工作原理&#xff1a; 1.客户端会发送请求到vip 2.LVS的调度器接受请求之后&#xff0c;根据算法选择一台真实服务器&#xff0c;请求转发到后端RS&#xff0c;请求的报文的目的MAC地址&#xff0c;修改成后端真实服务器的MAC地址&#xff0c;转发。 3.后端真实服务器…

应用3之Like运算符的应用

《VBA经典应用69例》&#xff08;10178981&#xff09;&#xff0c;是我推出的第九套教程&#xff0c;教程是专门针对初级、中级学员在学习VBA过程中可能遇到的案例展开&#xff0c;这套教程案例众多&#xff0c;紧贴“实战”&#xff0c;并做“战术总结”&#xff0c;以便大家…

在Web中搜索(Searching the Web, ACM/ICPC Beijing 2004, UVa1597)rust解法

输入n篇文章和m个请求&#xff08;n<100&#xff0c;m≤50000&#xff09;&#xff0c;每个请求都是以下4种格式之一。 A&#xff1a;查找包含关键字A的文章。 A AND B&#xff1a;查找同时包含关键字A和B的文章。 A OR B&#xff1a;查找包含关键字A或B的文章。 NOT A&…

MySQL中如何处理重复数据(Duplicate)?

在MySQL中&#xff0c;处理重复数据&#xff08;Duplicate&#xff09;的主要方式是使用INSERT INTO ... ON DUPLICATE KEY UPDATE语句或REPLACE INTO语句。 INSERT INTO ... ON DUPLICATE KEY UPDATE语句&#xff1a;该语句在插入数据时&#xff0c;如果遇到唯一键冲突&#x…

医药电商行业想要精准获客?媒介盒子分享三大技巧

随着医疗需求的不断增长&#xff0c;健康成为社会关注的重点&#xff0c;消费者对医药保健产品和需求正在不断增长&#xff0c;数字化时代的来临使医药行业逐渐电商化&#xff0c;线上零售渠道成为医药行业销售额的主要来源&#xff0c;那当下医药电商行业如何抓住机遇&#xf…

怎么快速、合法地挣到一百万?

大部分的人都想要在互联网上面赚到属于自己的那份钱 这类分为两类&#xff0c;一种是纯新人&#xff0c;没有接触过任何行业&#xff0c;所要做的是能够让人帮你根据自己的情况完成筛选&#xff0c;看哪些基础简单的事情可以去做。 第二类已经有项目经验的人&#xff0c;这时…

AB试验(六)A/B实验常见知识点的Python计算

AB试验&#xff08;六&#xff09;A/B实验常见知识点的Python计算 前面理论知识上提到了很多的知识点需要计算&#xff0c;作为一个实用主义的博主&#xff0c;怎么可以忍受空谈呢&#xff1f;所以本期就给大家分享如何利用Python对这些知识点进行计算。 均值类指标 import …

上架用的SDK三方应用隐私

SDK名称&#xff1a;华为推送 使用目的&#xff1a;用于向华为手机用户推送消息 使用场景&#xff1a;用户账号相关促销活动、消息提醒更新时 信息收集类型&#xff1a;设备相关信息&#xff08;Android_ID&#xff09;使用的敏感权限&#xff1a;不涉及 使用的敏感权限&am…

一起学数据结构(11)——快速排序及其优化

上篇文章中&#xff0c;解释了插入排序、希尔排序、冒泡排序、堆排序及选择排序的原理及具体代码实现本片文章将针对快速排序&#xff0c;快速排序的几种优化方法、快速排序的非递归进行解释。 目录 1. 快速排序原理解析以及代码实现&#xff1a; 2. 如何保证相遇位置的值一…

嵌入式硬件库的基本操作方式与分析

本次要介绍的开源软件是 c-periphery&#xff1a; https://github.com/vsergeev/c-periphery一个用 C 语言编写的硬件外设访问库。 我们可以用它来读写 Serial、SPI、I2C 等&#xff0c;非常适合在嵌入式产品上使用。 我们可以基于它优秀的代码框架&#xff0c;不断地扩展出更…

Prometheus接入AlterManager配置邮件告警(基于K8S环境部署)

文章目录 一、配置AlterManager告警发送至邮箱二、Prometheus接入AlterManager配置三、部署PrometheusAlterManager(放到一个Pod中)四、测试告警 注意&#xff1a;请基于 PrometheusGrafana监控K8S集群(基于K8S环境部署)文章之上做本次实验。 一、配置AlterManager告警发送至邮…