Radis初阶 Radis基本命令与在Springboot中访问Radis

news2024/10/7 9:24:30

阿里网盘链接

文章目录

    • 初始NoSQL数据库
      • 对比MySQL数据库
        • 从结构方面:
        • 从关系方面:
        • 从查询方式:
        • 从事物方面:
    • Redis入门
      • Redis数据结构
      • 访问Radis
        • 通用命令(tab键:自动补全)
          • KEYS
          • DEL
          • EXISTS
          • EXPIRE
          • TTL
        • String类型常见命令
          • SET
          • GET
          • MSET
          • MGET
          • INCR
          • INCRBY
          • DECR
          • SETNX
          • SETEX
        • Hash类型常见命令
          • HSET
          • HGET
          • HMSET
          • HMGET
          • HGETALL
          • HKEYS
          • HVALS
          • HINCRBY
        • List类型常见命令
          • LPUSH
          • LPOP
          • RPUSH
          • RPOP
          • LRANGE
          • BLPOP
          • BRPOP
        • Set类型常见命令
          • SADD
          • SREM
          • SCARD
          • SISMEMBER
          • SMEMBERS
          • SINTER
          • SDIFF
          • SUNION
        • SortedSet类型常见命令
          • ZADD
          • ZREM
          • ZSCORE
          • ZRANK
          • ZCARD
          • ZCOUNT
          • ZINCRBY
          • ZRANGE
          • ZRANGEBYSCORE
          • ZRANGEBYSCORE
          • ZDIFF/ZINTER/ZUNION
      • 使用KEY命令
    • java的radis编程客户端(Spring Data Radis整合了Jedis和Lettuce)
      • Jedis客户端的使用
      • Jedis链接池
      • Springboot集成springDataRedis使用步骤
      • RedisTemplate的RedisSerializer序列化工具
          • 自定义RedisSerializer步骤
      • StringRedisTemplate向radis客户端传入对象数据

初始NoSQL数据库

对比MySQL数据库

从结构方面:
  1. SQL数据库是一个结构化的数据库:对于数据库中的每一个字段都有相对应的严格的约束。约束不好进行修改

  2. NoSQL数据库是一个非结构化的数据库:

    • 键值型数据库,对键和值的定义约束很随意

    • 文档型,将数据一条一条的存储进去,一般使用json,字段描述是任意的id、name都可以

    • 图类型(graph)数据库,数据作为结点,用联系连接

从关系方面:
  1. SQL:有关联的数据库使用外键以关联两个表之间的关系。具体体现在两个已经关联的表不能轻易删除其中一个;
  2. NoSQL:无关联的数据库使用json嵌套的方式描述表之间的关系。首先没有关联,有冗余。
从查询方式:
  1. SQL查询的语法相对固定
  2. NoSQL查询的语法使用相对宽松,没有相对的标准,不同的NoSQL数据库的查询语法都不同。
    • 使用起来相对起来简单,熟悉
从事物方面:
  1. SQL满足ACID
  2. NoSQL满足BASE,不能完全满足ACID

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Redis入门

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Redis数据结构

redis是一个键值型的数据库,key一般是String类型,不过value有多种数据类型

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

redis命令行的使用

官方文档(可以使用edge浏览器翻译)

访问Radis

我们有两种方式来访问Radis数据库

  1. 命令行客户端

    • 使用语法:

    • redis-cri -h ... -p [端口号]

      AUTH 123321

  2. 图形化客户端

通用命令(tab键:自动补全)

命令行查看通用命令

help [commands]{keys/del}

KEYS

查看符合模板的所有key,不建议在生产环境下使用。因为它采用的事模糊查询

查询所有

key *

DEL

删除多个指定的key

del k1 k2 k3

EXISTS

判断一个值是否存在

EXISTS age

EXPIRE

给一个key设置有效期,有效期到时key会被自动删除(单位:秒)

EXPIRE number 16

TTL

查看一个key的剩余有效期(-1 表示永久有效,-2表示没有查询到)

TTL number

String类型常见命令
SET

添加或修改一个已经存在的一个String类型的键值对

SET age 18

GET

根据key获取String

GET age

MSET

批量添加多个String类型的键值对

MSET k1 v1 k2 v2 k3 v3

MGET

批量添加多个key获取多个String类型的数据

GET k1 k2 k3

INCR

让一个整数型的key自增1

INCR age

INCRBY

让一个整数型的key按照指定步长自增

INCRBY age 2

DECR

让一个整数型的key自减1

DECR age

INCRBYFLOAT

让一个浮点数增长指定步长

INCRBYFLOAT score 0.5

SETNX

添加一个String类型的键值对,前提是这个key不存在,否则不知选哪个

SETNX name2 lisi

SETEX

添加一个String类型的键值对,并指定有效期(单位:秒)

SETEX name 20 wangwu

Hash类型常见命令

Hash结构可以将对象中的每一个字段独立存储,对单个字段做CRUD

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

HSET

添加或者修改hash类型key的field的值

HSET me:user:3 age 71

HGET

获取一个hash类型的key的value值

HGET me:user:3 age

HMSET

添加多组hash类型的key的value值

HMSET me:user:3 name Lili age 20 sex man

HMGET

获取多个hash类型的key的value值

HMGET me:user:3 name age sex

HGETALL

获取所有指定的key

HGETALL me:user:3

HKEYS

获取一个Hash类型中key的所有的field

HKEYS me:user:3

HVALS

获取一个Hash类型中key所有的value

HVALS me:user:3

HINCRBY

使得Hash类型中的一个字段自增

HINCRBY me:user:3 age 2

List类型常见命令

Redis中的List类型可以看做是一个双向链表的结构。可以正向检索和反向检索。

特点:

  • 有序
  • 元素可以重复
  • 插入和删除速度快
  • 查询速度一般
LPUSH

向列表左侧插入一个或多个元素

LPUSH users 1 2 3

LPOP

移除并返回列表左侧的第一个元素(单位个数)

LPOP 1

RPUSH

向列表右侧插入一个或多个元素

LPUSH users 4 5 6

RPOP

移除并返回列表右侧的第一个元素(单位个数)

RPOP 1

LRANGE

返回一段角标范围内的所有元素

LRANGE 1 2

BLPOP
BRPOP
Set类型常见命令

Redis的Set结构与java中的HashSet类似,可以看做是一个value为null的HashMap。因为也是一个Hash表,因此具备与HashSet类似的特征:

  • 无序
  • 元素不可重复
  • 查找快
  • 支持交集、并集、差集等功能
SADD

向set中添加一个或多个元素

SADD s1 a b c

SREM

移除set中的指定元素

SADD s1

SCARD

返回set中的元素个数

SCARD s1

SISMEMBER

判断一个元素是否在set中

SISMEMBER s1 a

SMEMBERS

获取set中的所有元素

SMEMBERS s1

SINTER

求set1和set2的交集

SINTER set1 set2

SDIFF

求set1和set2的差集

SDIFF set1 set2

SUNION

求set1和set2的并集

SUNION set1 set2

SortedSet类型常见命令

可以排序的ste集合。SortedSet的每一个元素都带有一个score属性,可以基于score属性对元素排序,底层的实现是一个跳表加Hash表;SortedSet具备下列特性:

  • 可排序性
  • 元素不重复
  • 查询速度快

注意:经常被用于排行表这个功能

ZADD

添加一个或多个元素到Sortedset,如果已经存在,则更新

ZREM

删除Sortedset中的一个指定元素

ZSCORE

获取Sortedset中的指定元素的score值

ZRANK

获取Sortedset的指定元素的排名

ZCARD

获取Sortedset中元素的个数

ZCOUNT

统计score值在给定范围内的所有元素的个数

ZINCRBY

让Sortedset中的指定元素自增,步长为制定的值

ZRANGE

按照score排序后,获取指定排名范围内的元素

ZRANGEBYSCORE

按照score排序后,获取制定score范围内的元素

ZRANGEBYSCORE

按照score排序后,获取指定score范围内的元素

ZDIFF/ZINTER/ZUNION

求差集、交集、并集

使用KEY命令

层级格式存储:用于分别不同类型的数据

set me:user:2 ‘{“id”:2,“name”:“Rose”,“age”:18}’

set me:product:1 ‘{“id”:2,“name”:“小米11”,“price”:4999}’

图形客户端中会自动形成文件夹分级,从而实现观感上的提升

java的radis编程客户端(Spring Data Radis整合了Jedis和Lettuce)

Jedis客户端的使用

Jedis官方网址

  1. 常见一个Maven工程
  2. 引入Jedis依赖和单元测试依赖(junit5)
  3. 建立连接
private jedis jedis;
    
@BeforeEach
void setUp(){
	// 建立连接 (第一个参数,radis客户端的ip地址;第二个参数,radis客户端的端口号)
    jedis = new Jedis("192.168.150.101",6379);
    // 设置密码
    jedis.auto("123321");
    // 选择(第一个)库
    jedis.select(0);
}
  1. 测试string
@Test
void testString(){
    // 插入数据,方法就是radis的名称
    String result = redis.set("name","张三");
    System.out.println("result = " + result);
    // 获取数据
    String name = jedis.get("name");
    System.out.println("name = " + name);
}

@Test
void testHash(){
    // 插入Hash数据
    jedis.hset("user:1","name","jack");
    jedis.hset("user:1","age","18");
    // 获取hash数据资源
    Map<String, String> map = jedis.hgetAll("user:1");
    // 打印输出
    System.out.println(map);
}
  1. 释放资源
@AfterEach
void tearDown(){
    // 释放资源
    if(jedis != null){
        jedis.close();
    }
}

Jedis链接池

public class JedisConnectionFactory{
    private static final JedisPool jedisPool;
    
    static{
        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
        // 最大链接
        jedisPoolConfig.setMaxTotle(8);
        // 最大空闲连接
        jedisPoolConfig.setMaxIdle(8);
        // 最小空闲连接
        jedisPoolConfig.setMinIdle(0);
        // 设置最长等待时间,ms
        jedisPoolConfig.setMaxWaitMillis(200);
        // 参数分别为连接池对象、redis的ip地址、端口号、密码
        jedisPool = new JedisPool(jedisPoolConfig,"192.168.150.101",6379,1000,"123321")
    }
    
    // 获取Jedis对象
    public static Jedis getjedis(){
        return jedisPool.getResource();
    }
}

步骤:

  1. 配置连接池

  2. 创建连接池对象

  3. 上面的“建立连接”步骤可以改为:

    • jedis = JedisConnectionFactory.getjedis();
  4. 关闭连接的操作也在底层中与前面的略有区别(改为了释放资源)

Springboot集成springDataRedis使用步骤

spring 已经自动整合了SpringDataRedis,并且已经自动装配

步骤:

  1. 引入依赖
<!--Redis依赖-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

<!--连接池依赖-->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>common-pools</artifactId>
</dependency>
  1. 配置radis的地址信息(yml)
spring:
	redis:
	host:192.168.150.101
	port:6379
	password:123321
	lettuce:
		pool:
			max-active:8 #最大连接数量
			max-idle:8 #最大空闲连接
			min-idle:0 #最小空闲连接
			max-wait:100 #连接等待时间
  1. 注入RedisTemplate(自动装配:拿来就用)
@Autowired
private RedisTemplate redisTemplate;
  1. 编写测试
@SpringBootTest
public class RedisTest{
    @Autowired
    private RedisTemplate redisTemplate;
    
    @Test
    void testString (){
        // 插入一条String类型的数据
        redisTemplate.opsForValue().set("name","李四");
        // 读取一条String类型的数据
        Object name = redisTemplate.opsForValue().get("name");
        System.out.println("name=" + name);
    }
}

RedisTemplate的RedisSerializer序列化工具

原生的radis使用的是JDK的RedisSerializer,但是在实际应用中,生成的key和value是不好用的,key的字符串非常的长;value的字符串转换为了16进制数。

自定义RedisSerializer步骤
  1. 在pom中引入Jackson依赖
<!--jackson依赖-->
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
</dependency>

将类用@Configuration注释后使用

@Bean
public RedisTemplate<String,Object> redisTemplate(RadisConnectionFactory radisConnectionFactory) throws UnknownHostException{
    // 创建Template对象
    RedisTemplate<String,Object> redisTemplate = new RedisTemplate<>();
    // 设置连接工厂
    redisTemplate.setConnectionFactory(radisConnectionFactory);
    // 设置序列化工具
    GenericJackson2JsonRedisSerializer jsonRedisSerializer = new GenericJackson2JsonRedisSerializer();
    // key和hashKey采用string序列化
    redisTemplate.setKeySerializer(RedisSerializer.toString());
    redisTemplate.setHashValueSerializer(RedisSerializer.toString());
    // value和hashValue采用JSON序列化
    redisTemplate.setValueSerializer(jsonRedisSerializer);
    redisTemplate.setHashValueSerializer(jsonRedisSerializer);
    return reidsTemplate;
}外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-home.csdnimg.cn/images/20230724024159.png?origin_url=https%3A%2F%2Fimg.picui.cn%2Ffree%2F2024%2F06%2F15%2F666cf0e6c9acb.png&pos_id=img-m430JoJ7-1718416816392)

StringRedisTemplate向radis客户端传入对象数据

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

@Autowired
private StringRedisTemplate stringRedisTemplate;
// JSON工具
private	static final Objectmapper mapper = new ObjectMapper();
@Test
void testStringTemplate() throws JsonProcessingException{
    // 准备工作 实体类的创建
    User user = new User("虎哥"18);
    // 手动序列化
    String json = mapper.writeValueAsString(user);
    // 写入一条数据到redis
    stringRedisTemplate.opsForValue().set("user:200",json);
    
    // 读入数据
    String val = stringRedisTemplate.opsForValue().get("user:200");
    // 反序列化
    User user1 = mapper.redisValue(val,User.class);
    System.out.println("user1 = " = user1);
}

注意:在将上述代码封装成工具类之后,可以省略掉 准备工作手动序列化 这两个步骤

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

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

相关文章

硬件SPI读写W25Q64

硬件SPI读写W25Q64 接线图&#xff08;和软件SPI一样&#xff09; 使用SPI1&#xff0c;SCK&#xff0c;接PA5&#xff1b;MISO&#xff0c;接PA6&#xff1b;MOSI&#xff0c;接PA7&#xff1b;NSS&#xff0c;可接PA4。 接线图对应&#xff1a;PA5接CLK引脚&#xff0c;PA6…

军事武器3D数字化交互展示创作平台大大降低成本

军事力量和装备是一个国家国防安全的重要支柱&#xff0c;这在全球范围内得到广泛认同&#xff0c;为了让入伍的新兵能快速熟悉和掌握武器装备操作流程&#xff0c;基于创新型的华锐3D云展平台工具&#xff0c;搭建的3D军事武器展示搭建编辑器&#xff0c;让部队的军事武器展示…

Apollo9.0 PNC源码学习之Control模块(一)—— 控制模块概览

0 前言 从planning的角度看control&#xff0c;首先需要了解的就是相关的数据接口&#xff0c;规划出的轨迹&#xff08;路径速度&#xff09;发给Control模块去执行 modules/planning/planning_component/planning_component.cc planning模块发布轨迹信息 planning_writer_ …

程序员基本功之git的使用

阿里网盘-资料链接 文章目录 git分布式版本控制工具git的基本概念开发过程中的问题常见的版本控制工具git分布式版本控制工具特点git系统所定制的若干目标git的工作流程图 GIT的安装和常用命令**创建本地git仓库步骤****本地git仓库的使用**git log详解 git分布式版本控制工具…

大模型系列:Prompt提示工程常用技巧和实践

前言 Prompt提示语是使用大模型解决实际问题的最直接的方式&#xff0c;本篇介绍Prompt提示工程常用的技巧&#xff0c;包括Zero-Shot、Few-Shot、CoT思维链、Least-to-Most任务分解。 内容摘要 Prompt提示工程简述Prompt的一般结构介绍零样本提示Zero-Shot少样本提示Few-Sho…

Ubuntu 18.04下普通用户的一次提权过程

Ubuntu 18.04下普通用户的一次提权过程 一.背景介绍:二.主要调试过程:三.相关命令:1.设置BMC密码,获取BMC IP2.找一台ubuntu搭建TFTP服务,用来替换grub.cfg文件3.从调试服务器的/boot/grub/grub.cfg中提取出recovery mode的配置,简化并生成新的配置文件grub.cfg,放在tftp服务的…

从零开始学习RecyclerView

1、实现最简单的一个控件列表 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:tools"http://schemas.android.com/tools"android:layout_width&qu…

Maven常用命令介绍(Ⅰ)

基本命令 Maven生命周期 Maven的生命周期是对所有的构建过程进行抽象和统一。Maven的生命周期是抽象的&#xff0c;这意味着生命周期本身不做任何实际的工作&#xff0c;生命周期只是定义了一系列的阶段&#xff0c;并确定这些阶段的执行顺序。而在执行这些阶段时&#xff0c;…

08 SpringBoot 自定定义配置

SpringBoot自定义配置有三种方式&#xff1a; 使用PropertySource进行自定义配置 使用ImportResource进行自定义配置 使用Configuration进行自定义配置 PropertySource ​ 如果将所有的配置都集中到 application.properties 或 application.yml 中&#xff0c;那么这个配置文…

秋招突击——第四弹——Java的SSN框架快速入门——Maven

文章目录 引言Maven分模块开发与设计分模块开发的过程 依赖管理可选依赖与排除依赖 继承与聚合聚合继承 属性和版本管理属性扩大集中管理的范围版本管理 多环境开发多环境开发 私服简介安装私服资源操作流程分析上传和下载 总结 引言 前一个部分花了太多时间&#xff0c;后续得…

音视频集式流媒体边缘分布式集群拉流管理

一直以来&#xff0c;由于srs zlm等开源软件采用传统直播协议&#xff0c;即使后面实现了webrtc转发&#xff0c;由于信令交互较弱&#xff0c;使得传统的安防监控方案需要在公网云平台上部署大型流媒体服务器&#xff0c;而且节点资源不能统一管理调度&#xff0c;缺乏灵活性和…

链表经典题目:环形链表问题(LeetCode141.环形链表、LeetCode142.环形链表Ⅱ)

&#x1f4c7;文章目录 &#x1f4dc; LeetCode141. 环形链表&#x1f536;题目描述&#x1f537;思路分析✔️代码实现 &#x1f4dc; LeetCode142.环形链表Ⅱ&#x1f536;题目描述&#x1f537;思路①✔️代码实现&#x1f537;思路② &#x1f4d2;总结 &#x1f4dc; Leet…

父亲节马上到了-和我一起用Python写父亲节的祝福吧

前言 让我们一起用Python写一段父亲节的祝福吧 &#x1f4dd;个人主页→数据挖掘博主ZTLJQ的主页 个人推荐python学习系列&#xff1a; ☄️爬虫JS逆向系列专栏 - 爬虫逆向教学 ☄️python系列专栏 - 从零开始学python 话不多说先上代码 import tkinter as tk from doctest imp…

【GD32F303红枫派使用手册】第十六节 USART-DMA串口收发实验

16.1 实验内容 通过本实验主要学习以下内容&#xff1a; 串口DMA工作原理 使用DMA进行串口收发 16.2 实验原理 16.2.1 串口DMA工作原理 在前面ADC章节中&#xff0c;我们介绍了DMA的工作原理&#xff0c;这里就不多做介绍。从GD32F303用户手册中可以查到&#xff0c;各串…

CrossOver 2024软件安装包下载

CrossOver不像Parallels或VMware的模拟器&#xff0c;而是实实在在Mac OS X系统上运行的一个软件。CrossOvers能够直接在Mac上运行Windows软件与游戏&#xff0c;而不需虚拟机。它为Windows软件提供所需的资源&#xff0c;以达到在Mac OS X系统上运行Windows程序的目的。 安 装…

Android屏幕旋转流程(1)

&#xff08;1&#xff09;Gsensor的注册和监听 App -->I2C过程&#xff1a;App通过SensorManager.getSystemServer调用到SystemSensorManager&#xff0c;SystemSensorManager通过jni调用到SensorManager.cpp&#xff0c;后通过binder调用到SensorService。SensorService通…

使用Python和TCN进行时间序列预测:一个完整的实战示例

使用Python和TCN进行时间序列预测&#xff1a;一个完整的实战示例 时间卷积网络&#xff08;TCN&#xff09;已被证明在处理序列数据方面表现出色&#xff0c;尤其是在需要捕获长期依赖关系的任务中。在本文中&#xff0c;我们将通过一个简单的例子&#xff0c;展示如何使用Py…

洗地机哪款好?洗地机十大名牌排行榜

随着科技的发展&#xff0c;各种家居清洁工具层出不穷&#xff0c;为我们的生活带来了诸多便利。在众多清洁工具中&#xff0c;洗地机的清洁效果更受大家喜爱&#xff0c;它能够完美解决了扫地机无法做到的干湿垃圾“一遍清洁”效果&#xff0c;而且几乎能解决日常生活中所有的…

【Pandas驯化-02】pd.read_csv读取中文出现error解决方法

【Pandas】驯化-02pd.read_csv读取中文出现error解决方法 本次修炼方法请往下查看 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我工作、学习、实践 IT领域、真诚分享 踩坑集合&#xff0c;智慧小天地&#xff01; &#x1f387; 相关内容文档获取 微信公众号 &…

微型操作系统内核源码详解系列五(1):arm cortex m3架构

系列一&#xff1a;微型操作系统内核源码详解系列一&#xff1a;rtos内核源码概论篇&#xff08;以freertos为例&#xff09;-CSDN博客 系列二&#xff1a;微型操作系统内核源码详解系列二&#xff1a;数据结构和对象篇&#xff08;以freertos为例&#xff09;-CSDN博客 系列…