redis(1)---redis的安装以及五大基本类型的使用

news2024/10/5 16:20:15

一)认识NoSQL

格式化数据VS格式化

1)SQL关系型数据库,在关系型数据库里面表中的字段是有限制的,况且最好不要随意删除修改表结构,存入到关系型数据库中的数据,都是结构化的数据,对于这些数据都是必须要有格式化的要求,这些要求都是通过表的结构以及表的约束来进行定义的

2)比如说下面的用户表必须有三个字段,name,age和id,并且必须给id加约束,比如说加上主键约束,给name加上unique约束,不能重复,age加上unsigned,不能为负数

这些约束一旦定义好了,此时表的结构就固定了,将来我们插入表中的所有数据的时候,都需要严格地遵循这些约定,并且数据库也会对你插入的数据做校验,如果不符合这些约定,自然就会报错,不允许做插入;

3)但是NOSQL可以随意修改键值对的名字,键值型的关系型数据库redis,文档型数据库,字段任意,非常松散

关联性VS非关联性

表和表之间有着外键的关系,将来删除商品就会被不允许,数据库就会维护这些关系

1)关系型数据库通过嵌套的方式来进行关联,数据存储大量重复的数据,比如说张三买了荣耀6,但是李四也是可以买荣耀6的,非关系型数据库是不会帮你维护表和表之间的关系

2)但是我们的orders里面也是可以进行存储手机id,再来另外一张表来进行存储手机的信息,此时就需要依靠程序员的业务逻辑来进行维护了,因为非关系型数据库不会帮你进行维护表和表之间的关联关系,无关联数据;

 查询:

SQL查询语句固定,通用语法;

NOSQL:查询语法:不同的库有不同的语法

 事务:

NOSQL数据库无法满足事务

安装redis

1)yum安装redis:yum -y install redis

2)启动redis,使用以下命令以后台运行方式来进行启动redis

redis-server /etc/redis.conf&

3)启动redis:redis-cli

设置redis远程连接:

1)将redis配置文件下载到本地:redis配置文件是linux下面的/etc/redis.conf

2)将redis.conf中的"bind 127.0.0.1"注释掉

三)redis常见通用的命令:

redis一般是一个Key-Value的数据库,Key一般是String类型,但是value的类型多种多样

 可以通过help @hash/@generic(通用命令)/@string来查看帮助手册

常用命令:help+commond可以查看一个命令的具体用法

1)keys *:查看符合模版的所有key,查看keys的帮助文档就是help keys,

*代表所有底层是使用模糊匹配查询,搜索会很长时间,redis是单线程,在生产环境下不适合使用

 2)del:删除固定的key,返回值表示删除的个数,传一个删一个,传多个删多个

 3)exists+key值,返回值表示存在几个

help exists

exists name

exists age

 4)expire+key+seconds(key表示给谁设置有效期,seconds表示有效期的时长是多少)

给key设定一个有效期,有效期到期的时候这个key会自动删除

set key value ex 有效期时间

set name zhangsan ex 10

 5)TTL+Key值表示查看key的剩余有效时间

-1代表永远存在,-2表示不存在

1)过期时间一般用于设置session的过期时间(长时间不操作系统,redis的key失效,保证安全)

2)和一些缓存的保留时间,防止未更新的缓存没有被更新

6)persists+key取消key的过期时间

7)select+数字选择redis的数据库

8)pexpire key millionseconds设置key的过期时间时毫秒

9)move key otherindex转移此key到其他的数据库里面

10)更改名称key:rename oldkeyname newkeyname

11)randomkey随即返回一个key

12)flushdb:清空当前数据库中的所有key

13)flushall:清空所有数据库中的key

key的命名建议:key是区分大小写的,况且在一个项目中最好所有的key都是用统一的命名格式,例如:user:1:username 

 一)String类型

String类型也就是字符串类型,是redis中最简单的数据类型,其value是字符串,不过根据字符串的格式不同,又可以分成三类,不管是哪一种格式,在底层都是使用字节数组进行存储,只不过是编码形式不同,字符串类型的最大空间不能超过512M

1.1)String就是普通字符串

1.2)int:整数类型,可以做自增,自减操作

1.3)float:浮点类型,可以做自增,自减操作

String类型的常见命令:

1)set:添加或者修改已经存在的String类型的键值对

help set

2)get:根据key获取String类型的value

help get

3)mset:批量添加多个String类型的键值对,返回值就是多个值形成的一个数组

help mset

4)incr:让一个整形的key自增1

5)incrby:让一个整形的key并指定步长,比如说incrby num 2,就是在让num的值自增2,可以使用正数也可以使用负数,是用负数则是自减的效果

decrby

6)incrbyfloat:让一个浮点类型的数字自增并且指定步长

decrybyfloat

7)setnx:添加一个String类型的键值对,前提是这个key不存在,否则不执行,真正的新增功能,等同于set key value nx

8)setex:添加一个String类型的键值对,并且指定有效期,setex  key  seconds  value 

相当于是set key seconds ex+时间也是用来指定有效期的

相当于是一个组合命令:set key expire+时间

9)mget 获取多个key的值

10)type+key判断key的类型

11)getrange key start end:用于获取key中的字符串的子字符串

12)getbit key offset

13)strlen:返回key所对应的value的字符串的长度

二)key的层级格式:

1)因为redis中没有类似于MYSQL这样的Table的概念,如何来进行区分不同类型的Key呢?

比如说需要进行存储用户商品信息到redis,有一个用户ID是1,那么此时还有一个商品ID也是1

解决方案:Redis中的key是允许有多个单词组成层级结构,多个单词之间使用冒号来分开,格式如下:

项目名称:类型:ID的值

2)假设此时我们有一个项目名称叫做:BlogSystem,有user和blog两种不同的类型的数据,我们就可以这样来定义Key:

存放user相关的Key=value

BlogSystem:user:1=‘{id:"1","username:"zhangsan",password:"123456"}’

存放product相关的Key=value:

BlogSystem:product:1=‘{"id":1,"productname":"小米“,productprice:"20"}’

vaue值是把Java对象序列化成字符串的结果,如果说value是一个JAVA对象,那么可以将对象序列化成JSON字符串之后进行存储

set BlogSystem:user:1  '{id:"1",username:"zhangsan",password:"123456"}'

set BlogSystem:user:2 '{id:"2","username:"lisi",password:"123"}'

set BlogSystem:product:1 '{id:"1","productname":"小米“,productprice:"20"}'

set BlogSystem:product:2 '{id:"2","productname":"华为“,productprice:"30"}'

在图形化界面就可以形成了正常的层级结构,就实现了Key的分级存储

三)Hash类型:Map<String,Map<String,String>>

hash类型,也叫做散列,类似于Java中的HashMap

之前学习过的String结构是将对象序列化之后形成JSON格式的字符串来进行存储,但是当我们进行修改某一个字段的时候并不方便

但是此时哈希结构可以将对象中的每一个字段单独来进行存储,可以针对单个字段来做CRUD 

所以在Hash类型中,可以忽略原来的value 

常见的命令:

1)hash key field value:添加或者修改hash类型中的key的field的值

2)hget key filed:获取一个hash类型的key的fileld的值

3)hmset:批量添加多个hash类型的key的fileld的值

4)hmget:批量获取多个hash类型的key的filed的值

5)hgetall:获取一个hash类型的key的key中的所有field和value

6)hkeys:获取一个hash类型的key中的所有field的值

7)hvalues:获取一个hash类型的key中的所有value

8)hincrby:让一个hash类型的key的字段值自增并指定步长

9)hsetnx:坦加一个hash类型的key的field值,前提是这个field不存在,否则不执行

10)hlen+key获取key里面键值对的个数

11)hdel+key+filed1+filed2删除key中的多个键值对

12)hexists key filed判断一个key重的value是否存在

13)hincrbyfloat key field incrment让key中的一个小数以稳定字长增长

一)hset product:user:1 name zhangsan

hset+key+key.fileld+key.value

二)hget product:user:1 name

hget key+key.field

三)hmset product:user:1 name jackon age 10 classID 19 idadmin 1

上面就是一个id为1的用户,向数据库中存入了名字是jackon,classID是19,isadmin为1的用户信息

hmset key key.field1 key.value1 key.field2 key.value2 key.field3 key.value3

四)hmget product:user:1 name age classID isadmin

hmget key key.field1 key.field2 key.field3即可获取对应的key对应的field的value值

五)hgetall product:user:1
hgetall+key值即可获取这个key所对应的所有fileld值和value值

六) hincrby product:user:1 number 30

hincrby key值 key.field 要进行自增的值,后面也是可以是一个负数

七)hsetnx product:user:2 number 40

八) hdel user username password

九)hlen user

四)List类型:常用的是保存有序的顺序

redis中的List类型和Java中的LinkedList类型相似,可以看作是一个双向链表,既可以支持正向检索还可以支持反向检索,特征也是和LinkedList相似

1)有序

2)元素可以重复

3)插入和删除速度比较快

4)查询速度一般

常用命令:

1)lpush list名字 element.....向列表左侧插入一个或者多个元素

2)lpop list名字 数量 移除并返回列表中的第一个或者多个元素元素,没有那么直接返回null

3)rpush list名字 element:向列表右侧插入一个或者多个元素

4)rpop list名字 element:移除并返回列表右侧的第一个元素

5)lrange list名字 start end:返回一段角标范围内的所有元素

6)blpop brpop:和lpop和rpop类似,只不过是在没有元素的时候等待指定时间,而不是直接返回null,B表示阻塞;

1)lpush users 1 2 3,users代表list的名字

元素的顺序是 3 2 1

2)rpush users 4 5 6,users代表list的名字

3)lpop users 4,取出users这个list中的四个元素并且返回删除

4)blpop users 10,表示取出users这个list中的一个元素,如果没有等待10s后进行返回

如何使用list数据结构来模拟一个栈?

栈是一种先进后出的数据结构,入口和出口在同一边,rpush和rpop就是栈

如何使用list数据结构来模拟一个队列?

队列是一种先进后出的数据结构,入口和出口不在同一边,rpush和lpop就是队列

如何使用list数据结构来模拟一个阻塞队列?

首先是队列,况且入口和出口在不同边,blpop,brpop

五)redis的Set类型

redis中的Set集合是和Java中的HashSet类似,可以看作是一个value=null的HashMap

也是一个哈希表,因此也具备和HashSet类似的特征

没有顺序,元素不可重复,查找快,支持交集,并集,差集等功能

常见命令:

1)sadd key number:向Set中添加一个或者多个元素

2)srem key number:移除set中的指定元素

3)scard key:返回set集合中的元素的个数

4)sismember key number:判断一个元素是否存在于Set中

5)smembers:获取Set中的所有的元素

6)sinter key1 key2求key1和key2两个元素集合的交集

7)sdiff key1 key2求key1和key2两个元素的差集

就是求key1里面存在的但是key2里面不存在的

8)union key1 key2:求key1和key2的并集

1)sadd set 1 2 3
2)srem set 1
3)scard set

4)sismember set 1 

5)smembers set

1)sadd set1 lisi wangwu zhaoliu

2)sadd set2 wangwu mazi ergou

3)scard set1

4)sinter set1 set2

5)sdiff set1 ste2

6)union set1 set2

7)sismember lisi set1

8)sismember zhangsna set2

9)srem set1 lisi

 六)SortedSet类型:

分数在前,元素在后

redis的SortSet是一个可以进行排序的set集合,和JAVA中的TreeSet有些类似,但是底层的数据结构差异却非常大,SortedSet中的每一个元素都带有一个Score属性,底层的实现是一个跳表加上哈希表,SortedSet具备以下特性:

可以进行排序

元素不重复

查询速度快

因为SortedSet这样的可排序特性,经常用来实现排行榜这样的功能

SortedSet中的常见命令:

1)zadd key score mumber:添加一个元素或者多个元素到sortedSet

如果已经存在那么直接更新SortedSet的值

 zadd key score1 member1 score2 member2

2)zrem key member:删除SortedSet中的一个指定元素

3)zscore key member:获取到SortedSet中的指定元素的score值

4)zrank key member:获取到SortedSet中指定元素的排名

zrevrank key member:降序排名

5)zcard key:获取到sortedset中的元素个数

6)zcount key min max:统计score值在给定范围内所有元素的个数,查询的是数量

7)zincrby key increment member:让sortSet中的元素自增,步数为指定的increment值

8)zrange key min max:按照score排序之后,获取指定排名范围之内的元素,查询的是具体的元素,默认是升序

zrevrange默认是降序

9)zrangebyscope key min max:按照score排序之后,获取指定score范围内的元素

10)zdiff zinter zunion:求交集,差集,并集

 这里面的key是 student

1)zadd student  85 jack 89  lucy  82 rose 95 tom 78 jerry 92 amy 76 miles

2)zrem student tom;

3)zrank student rose;

4)zcount student 0 80

5)zincrby student 2 tom

6)zrange student 0 2:获取0-2名的元素

7)zrevrange student 0 2:获取倒序的0-2的元素

8)zrangebyscore student 0 80查找出从0-80分的所有同学

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

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

相关文章

sentinel 随笔 2-流控

0. 想要个半个月的旅游 最近发现算法比较有意思一些&#xff0c;什么企业框架都是看不完的… 书接 FlowSlot 1. FlowRuleChecker.checkFlow() : 配置的规则校验类 sentinel 并没有对这个Checker进行抽象的设计&#xff0c;第一次看有些别扭… package com.alibaba.csp.sent…

01- 综述 (目标检测)

要点&#xff1a; 区分One-stage detector 和 Two-stage detector 参考链接&#xff1a;深度学习目标检测最全综述 - 爱码网 详细模型解读参考&#xff1a;目标检测简介 - 知乎 一 目标检测分类 1.1 发展历程 检测网络发布历程&#xff1a; 1.2 检测模型分类 2014年后目标…

C嘎嘎~~ [类 下篇之运算符重载]

类 下篇 之运算符重载 5.赋值运算符重载5.1运算符重载5.1.1 运算符的概念5..1.2 重载运费符的位置5.1.3运算符重载的实质 5.2 赋值运算符重载5.2.1深刻理解---编译器生成的默认赋值运算符重载5.2.2深刻理解---拷贝构造和赋值运算符重载5.2.3深刻理解---传参和返回值用引用修饰…

CUDA error: device-side assert triggered CUDA kernel errors might be asynchronously reported at some

问题描述&#xff1a; 在修改代码时&#xff0c;出现入下报错。 发生异常: RuntimeError CUDA error: device-side assert triggered CUDA kernel errors might be asynchronously reported at some other API call,so the stacktrace below might be incorrect. For debuggi…

Android Switch开关按钮使用和自定义样式(系列教程五)

Switch开关按钮简介 Switch开关按钮是Android中的基本控件之一&#xff0c;其本质上也是一个按钮&#xff0c;具有开和关两种展示状态。 Switch开关按钮基本使用 在布局文件中定义开关按钮&#xff1a; <LinearLayoutandroid:layout_width"300dp"android:layo…

Vivado安装后添加器件库

1.前言 通常安装Vivado时&#xff0c;由于软件完整安装的空间需求过于庞大&#xff0c;一般只会选择一部分器件进行安装。而随着学习和工作的进展&#xff0c;遇到新的赛灵思朋友是成长的里程碑&#xff0c;也是综合不能通过的绊脚石。 今天有幸认识了一位新的赛灵思朋友——…

云原生: istio+dapr构建多运行时服务网格

2020 年&#xff0c;Bilgin Ibryam 提出了 Multi-Runtime&#xff08;多运行时&#xff09;的理念&#xff0c;对基于 Sidecar 模式的各种产品形态进行了实践总结和理论升华。那到底什么是多运行时呢&#xff1f;首先还是得从分布式应用的四大类基本需求讲起。简单来讲任何分布…

刷题练习3

文章目录 题目一分析题解 题目二分析第一种第二种 题解第一种方法代码第二种方法代码 题目一 题目链接 描述 读入一个字符串str&#xff0c;输出字符串str中的连续最长的数字串 输入描述&#xff1a; 个测试输入包含1个测试用例&#xff0c;一个字符串str&#xff0c;长度不超…

牛顿迭代法解超越方程

牛顿迭代法解超越方程 L g T 2 2 π t a n h ( 2 π L d ) L\frac{gT^2}{2\pi}tanh(\frac{2\pi}{L}d) L2πgT2​tanh(L2π​d) 方程&#xff1a; f ( L ) L − g T 2 2 π t a n h ( 2 π L d ) 0 f(L)L-\frac{gT^2}{2\pi}tanh(\frac{2\pi}{L}d)0 f(L)L−2πgT2​tanh(L2π…

~项目启动~

rmq是什么&#xff1f; "rmq" 可能指的是 "RabbitMQ"&#xff0c;它是一种开源消息队列软件&#xff0c;采用 AMQP&#xff08;Advanced Message Queuing Protocol&#xff09;协议&#xff0c;可以用于支持异步处理、任务分发、解耦合等应用场景。Rabbit…

仪表检测与读数(一):仪表检测

基于YOLOv4的仪表检测 前言YOLOv4源码下载数据集处理与模型训练模型性能测试 前言 本系列是想记录一下自己实现的一种用于仪表检测与读数的方法&#xff0c;首先方法仅针对于单指针仪表和单行显示的数字仪表进行了检测与读数方法的设计。方法的整体思路是&#xff1a;第一步对拍…

[ 云计算 | Azure ] Chapter 06 | 计算服务之虚拟机、虚拟机规模集、Azure 容器、Azure App 与 Azure Functions

本系列已经更新文章列表&#xff08;已更新&#xff09;&#xff1a; [ Azure 云计算从业者 ] Chapter 03 | 描述云计算运营中的 CapEx 与 OpEx&#xff0c;如何区分 CapEx 与 OpEx[ Azure 云计算从业者 ] Chapter 04 | Azure核心体系结构组件之数据中心、区域与区域对、可用区…

【Qt】插件Plugin入门之Q_PLUGIN_METADATA()宏【2023.05.07】

摘要 分析Q_PLUGIN_METADATA宏的设计意图&#xff0c;站在设计者的意图进行插件的高屋建瓴式学习。 Meta-Object Compiler 简称MOC Qt 的 Meta-Object Compiler&#xff08;MOC&#xff09;是一个预处理器&#xff0c;用于处理带有特殊关键字的 C 文件&#xff0c;并生成用于…

Linux命令·netstat

netstat命令用于显示与IP、TCP、UDP和ICMP协议相关的统计数据&#xff0c;一般用于检验本机各端口的网络连接情况。netstat是在内核中访问网络及相关信息的程序&#xff0c;它能提供TCP连接&#xff0c;TCP和UDP监听&#xff0c;进程内存管理的相关报告。 如果你的计算机有时候…

详细版简单易学版TypeScript各类型声明

假如本地新建了一个b.ts文件 安装TypeScript&#xff1a;npm install -g typescript 编译代码&#xff1a;tsc b.ts 运行js&#xff1a;node b.js 在终端输入 tsc -init 生成 tsconfig.json 文件 类型注解&#xff1a;TypeScript里的类型注解是一种轻量级的为函数或变量添加约束…

Python中模块和包基础学习

目录 模块 引入模块 使用from...import语句引入模块中的指定变量或函数 使用import...as语句给模块起别名 使用dir()函数查看模块中的所有变量和函数 使用__name__变量判断模块是被导入还是直接执行 包 注意 示例 模块 Python中的模块是指一个文件&#xff0c;可以包…

2.1 掌握NumPy数组对象ndarray

2.1 掌握NumPy数组对象ndarray 2.2.1 创建数组对象1&#xff0e;数组创建2&#xff0e;数组属性&#xff1a;ndarray&#xff08;数组&#xff09;是存储单一数据类型的多维数组。3&#xff0e;数组数据类型 2.1.2 生成随机数random模块常用随机数生成函数 2.1.3 通过索引访问数…

Python中异常处理的学习

目录 异常的基本介绍 异常处理语句 抛出异常 异常的基本介绍 在Python中&#xff0c;如果程序出现错误&#xff0c;会抛出异常。异常是一种Python对象&#xff0c;它封装了错误的信息&#xff0c;并提供了一种处理错误的机制。Python中内置了很多异常类型&#xff0c;包括但…

C语言-学习之路-07

C语言-学习之路-07 内存管理作用域局部变量静态&#xff08;static&#xff09;局部变量全局变量extern全局变量声明全局函数和静态函数 内存分布内存分区 内存管理 作用域 C语言中变量的作用域可分为&#xff1a;代码作用域、函数作用域、文件作用域 局部变量 局部变量也叫…

C嘎嘎~~ [类 下篇(2)]

类 下篇2 5.赋值运算符重载5.1运算符重载5.1.1 运算符的概念5..1.2 重载运费符的位置5.1.3运算符重载的实质 5.2 赋值运算符重载5.2.1深刻理解---编译器生成的默认赋值运算符重载5.2.2深刻理解---拷贝构造和赋值运算符重载5.2.3深刻理解---传参和返回值用引用修饰 5.赋值运算符…