redis之数据类型

news2024/9/30 15:26:05

(一)关系型数据库和非关系型数据库的区别

1、关系型数据库是一个机构化的数据库,列和行

(1)列:声明对象
(2)行:记录对象的属性
(3)表与表之间是有关联的,使用sql语句来对指定表、库进行增删改查
(4)在创建表时,是设计好了表的结构,按照表结构来存储数据,数据与表结构不匹配,存储数据会失败
(5)关系型数据库:库——表——行、列——存储数据

2、非关系型数据库:nosql(not only sql)

(1)不需要定义库,也不需要定义表结构,直接记录即可,而且每条记录都可以有不同的数据类型,字段(字段个数)
(2)redis(key:value)键值对形式存储,每个键之间没有直接关联,库与库之间相互关联
(3)非关系型数据库:库——集合——键值对(不需要手动的创建库和集合)

3、区别

(1)数据的存储方式不同
(2)扩展方式,性能上的提升。关系型数据库靠的是提升本机性能;非关系型数据库可以横向扩展,加入节点服务器的方式提高性能
(3)对事务的支持性,mysql支持事务(原子性、隔离性、一致性、持久性);非关系型数据库也支持事务,redis也支持事务,但是稳定性和处理能力都不如关系型数据库

(二)redis

1、非关系型数据库的主要场景

(1)操作的扩展
(2)海量数据的处理

2、redis的主要目的——解决三高问题

(1)web2.0:交互
(2)纯动态网站的三高问题
①对数据库高并发读写的需求
②对海量数据高效存储与访问的需求
③对数据库的高扩展性与高可用性的需求

3、数据库缓存(常见的缓存需求场景)

①数据库缓存
②web页面缓存
③CPU和硬盘之间缓存

4、redis的相关概念

(1)redis开源的,使用c语言编写的NQL数据库
(2)redis:基于内促运行,支持持久化(数据恢复),采用的就是key-value(键值对)的存储方式,目前在分布式架构中,是非常重要的一环

5、常见架构

6、redis的工作特点

(1)redis服务器程序是一个单进程模式,即只有一个主进程工作,也就是说在一台服务器上可以启动多个redis(端口不能冲突)
(2)redis的实际处理速度是完全依靠主进程的执行效率
(3)问题:服务器只部署了一个redis进程,多个客户端访问可能会导致redis的处理能力下降;如果部署了多个redis进程,虽然能提高redis的并发处理能力,但是会给服务器的CPU带来很大的压力
(4)工作中:一台服务器一般部署3台redis进程(根据情况来看,高并发要部署多个,一般情况,单进程足够)

7、redis的特点

(1)具有极高的读写速度,数据读取每秒:110000次,写入数据每秒可以执行81000次
(2)支持丰富的数据类型
(3)支持持久化,平常的数据都是保存在内存中,持久化可以写入到磁盘中,既可以保存到本地(磁盘),也可以实现备份
(4)原子性,所有的操作都是原子性
(5)支持主从模式:master—slave模式
8、面试题:redis为什么这么快?
(1)redis是纯内存结构,避免磁盘I/O的耗时
(2)核心模块是一个单进程,减少了线程切换和回收线程的时间
(3)I/O的多路复用机制,每个执行线路都可以同时执行读和写,高并发的效率大大提高
*特殊说明:redis的读写任然是单进程处理

(三)部署redis

1、安装依赖环境:yum install -y gcc gcc-c++ make

2、编译

3、安装:make PREFIX=/usr/local/redis install

ln -s /usr/local/redis/bin/* /usr/local/bin/

4、redis的服务控制命令:/etc/init.d/redis_6379 stop 、start、restart、status

5、修改配置文件

(四)redis的命令工具

redis-server

直接启动redis,只能启动

redis-benchmark

检测redis在本机的运行效率

-h

指定服务器的主机名、IP地址

-p

指定服务器的端口号

-c

指定并发连接数

-n

指定请求数

redis-cil

命令行工具

-h

指定ip地址

-p

指定端口号

-a

指定登录密码

redis-check-aof

检测AOF文件是否正常

redis-check-rdb

检测rdb文件是否正常

(五)redis的数据类型

1、如何进入redis:redis-cli -h 20.0.0.41 -p 6379

(1)直接进入:redis-cli仅限于本地登录,远程登录还是需要指定目标服务器的ip地址

2、redis的五大数据类型

(1)string(字符串类型—数字、字符串):redis最基本的类型,最大能存储512MB的数据,可以存储任何数据,数字、文字、图片等等
(2)list:列表,列表中的元素还是string类型
(3)hash:用于存储对象,采用hash格式进行操作,占用的磁盘空间很少,一个hash可以存储42亿个键值对
(4)set(无序集合):元素类型也是string,元素是唯一的,不允许重复,多个集合类型之间可以进行并集、交集和差集运算
①应用场景:set当中的元素类型是唯一的,可以跟踪一些唯一性的数据,例如访问微博的用户名,只要把对应名称redis,set集合可以自动保存
(5)zset(有序集合):元素类型string,元素不能重复,唯一,每个元素都会关联一个double类型(小数点)的分数(score,表示权重),按照通过权重的大小进行排序,元素的权重可以相同
①zset应用场景:在线积分的排行榜,可以实时更新用户的分数
②zrange命令获取积分,zrank命令通过username获取用户的排行信息等等,按照权重有序排列

redis的五大数据类型

1、string(字符串类型):redis最基本的类型,最大能存储512MB的数据,可以存储任何数据,数字、文字、图片等等

查看键值对类型

keys *

模糊查询:

keys t*(查看任意以t开头的键值)

keys t??(查看任意以开头后面包含任意两个字符的键值)

创建键值对

set test 10

set test 10(set:创建、直接覆盖)

设置键值的生命周期(新建键值)

setex test2 15 yyy

setex test2 15 yyy

查看键值对的生命周期:ttl test

修改已有键值的生命周期:expire test2 30

查看键值是否存在

exists test

exists test

删除键值对

(del test)

del test

查看对应键的类型

(type test)

type test

append

(返回当前键的总长度)

#该键并不存在,因此append命令返回当前Value的长度

#该键已经存在,因此返回追加后Value的长度

获取指定键的字符长度

strlen test

strlen test

增减:incr、decr、incrby、decrby(key值必须为整数)

incr、decr

自增和自减1

incr test / decr test

incrby和decrby

指定整数增减

incrby test 5

decrby test 5

批量创建多个键值对

(mset)

mset test2 10 test3 10

同时打印多个键的值

(mget)

mget test2 test3

2、list数据类型(列表,列表中的元素还是string类型)

创建列表

lpush test1 a b

创建列表:lpush test1 a b c d

根据索引下标查看列表中的元素

lindex test1 2

lindex test1 2指定某一个索引下标位置

lrange info 1 2指定范围查看

正序创建列表

rpush info 1 2 3 4

rpush info 1 2 3 4

往列表中添加元素

删除列表中第一个元素

移除并返回mykey键的第一个元素,即从右往左第一个

lpop info1

获取列表的长度

llen info

修改列表中元素

lset info 3 5

在指定位置前进行插入元素

linsert info before 2 1

linsert info after 2 1

3、hash数据类型:用于存储对象,采用hash格式进行操作,占用的磁盘空间很少,一个hash可以存储42亿个键值对

创建hash键值

键名+字段名

hset hafo name aa

获取键值对的元素:hget hafo name

查看多个键值

hmget hafo name sex

删除键值

hdel hafo name sex

一次性设置多个字段

hmset info2 name 1 sex male tall 188

hgetall info2查看所有

hkeys info2:查看所有键、字段

hvals info2:查看所有键对应的值

删除键值

del info

4、set数据类型(无序集合),元素类型也是string,元素是唯一的,不允许重复,多个集合类型之间可以进行并集、交集和差集运算

(1)应用场景:set当中的元素类型是唯一的,可以跟踪一些唯一性的数据,例如访问微博的用户名,只要把对应名称redis,set集合可以自动保存

创建

sadd myset a b

查看元素

smembers myset

查看合集中的元素是否存在

sismember myset a

随机返回一个元素

srandmember myset

删除

随机删除一个元素:spop myset

指定名称删除:srem myset a d

5、zset有序集合:元素类型string,元素不能重复,唯一,每个元素都会关联一个double类型(小数点)的分数(score,表示权重),按照通过权重的大小进行排序,元素的权重可以相同

(1)zset应用场景:在线积分的排行榜,可以实时更新用户的分数

(2)zrange命令获取积分,zrank命令通过username获取用户的排行信息等等,按照权重有序排列

创建

zadd myzset 1 one 2 two 3 three

查看元素

查看元素:zrange myzset 0 -1

查看元素+权重:zrange myzset 0 -1 withscores

获取位置索引

zrank myzset one(元素)

查看成员数量

zcard myzset

查看权重范围

zcount myzset 1 2(1《元素》2)

删除元素

zrem myzset three(元素)

查看元素的权重

zscore myzset two

对已有键重命名

rename hafo haa(值不变)

补充:set和hset(创建普通类型和hash类型)的选择:一般情况下,如无特殊需求,普通创建即可,若对一个键进行多字段存储,节省内存,使用hash方式

查看当前库中键的数量

dbsize

切换库

select 0

redis的库都是创建好的,默认16个,数字排名0-15,美格库之间互相独立,互不干扰,默认是0

移动库的内容

move yyy 10

设置密码

config set requirepass 123456

在外声明密码:redis-cli -h 20.0.0.41 -p 6379 -a 123456

在内声明密码:auth 123456

清空当前数据库的数据

flushdb

清空所有库

(不能用)

flushall

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

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

相关文章

Python (十三) 输出

程序员的公众号:源1024,获取更多资料,无加密无套路! 最近整理了一波电子书籍资料,包含《Effective Java中文版 第2版》《深入JAVA虚拟机》,《重构改善既有代码设计》,《MySQL高性能-第3版》&…

使用pytorch利用神经网络原理进行图片的训练(持续学习中....)

1.做这件事的目的 语言只是工具,使用python训练图片数据,最终会得到.pth的训练文件,java有使用这个文件进行图片识别的工具,顺便整合,我觉得Neo4J正确率太低了,草莓都能识别成为苹果,而且速度慢,不能持续识别视频帧 2.什么是神经网络?(其实就是数学的排列组合最终得到统计结果…

Vue项目 配置项设置

一、项目运行时浏览器自动打开 找到package.json文件 找到"sctipts"配置项 在"serve"配置项最后加上--open "scripts": {"serve": "vue-cli-service serve --open","build": "vue-cli-service build&quo…

2023年【四川省安全员A证】复审考试及四川省安全员A证考试试题

题库来源:安全生产模拟考试一点通公众号小程序 四川省安全员A证复审考试根据新四川省安全员A证考试大纲要求,安全生产模拟考试一点通将四川省安全员A证模拟考试试题进行汇编,组成一套四川省安全员A证全真模拟考试试题,学员可通过…

Nacos介绍与使用

Nacos介绍与使用 文章目录 Nacos介绍与使用一. 什么是Nacos1 Nacos功能1.1 配置中心1.2 注册中心 2.为什么要使用Nacos 二.Nacos 部署安装1. Nacos 部署方式2. Nacos 安装3. 配置数据源4. 开启控制台授权登录(可选) 三. Nacos配置中心的使用1. 创建配置信…

2023/11/21JAVAweb学习

优先级高低id > 类 > 元素 格式化ctrl alt L

LeetCode热题100——动态规划

动态规划 1. 爬楼梯2. 杨辉三角3. 打家劫舍 1. 爬楼梯 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? // 题解:每次都有两种选择,1或者2 int climbStairs(int n) {if (n …

GAMES101—Lec 05~06:光栅化

目录 概念回顾(个人理解)光栅化1.采样2.采样出现的问题:走样 反走样 概念回顾(个人理解) 屏幕:在图形学中,我们认为屏幕是一个二维数组,数组里的每一个元素为一个二维像素。 光栅化…

【C++进阶之路】第四篇:set和map

文章目录 一、关联式容器健值对二、set & multiset三、map & multimap在这里插入图片描述 四、set和map底层原理 一、关联式容器健值对 关联式容器 & 键值对 二、set & multiset set & multiset 三、map & multimap map & multimap 四、set和…

【AT模式连接ONENET】ONENET可视化平台的使用

02 ONENET可视化平台的使用 ATCWMODE1 设置模式 ATCWDHCP1,1 启动DHCP功能 ①ATCWJAP"ssid","password" ATCWJAP“123456789”,“wang020118” ②ATMQTTUSERCFG0,1,"设备名字","设备ID","你的鉴权信息""…

JAVA项目测试----用户管理系统

一)项目简介: 用户管理系统是依据于前后端分离来实现的,是基于Spring SpringBoot Spring MVC,SpringAOP,MyBatis等框架来实现的一个用户管理网站,并且已经部署到了云服务器上, 目前的用户管理系统实现了超级管理员的注册功能&…

模电 01

一.半导体基本知识 1.优点:体积小、重量轻、使用寿命长、输入功率小、功率转换效率高。 2.性能介于导体与绝缘体 3.常用半导体材料:硅(SI) 镉(Ge),化合物半导体:砷化镓(GaAs&…

【封装UI组件库系列】全局样式的定义与重置

封装UI组件库系列第二篇样式​​​​​​​ ​​​​​​🌟前言 🌟定义全局样式 生成主题色和不同亮度的颜色 ​编辑 中性色及其他变量 🌟样式重置 🌟总结 ​​​​​​​​​​​​​​🌟前言 在前端开发中&…

SpringBoot趣探究--1.logo是如何打印出来的

一.前言 从本篇开始,我将对springboot框架做一个有趣的探究,探究一下它的流程,虽然源码看不懂,不过我们可以一点一点慢慢深挖,好了,下面我们来看一下本篇的知识,这个logo是如何打印出来的&#…

2014年2月24日 Go生态洞察:FOSDEM 2014上的Go演讲精选

🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…

【Echart】Echart设置label太长隐藏:

文章目录 第一种:竖排显示第二种:显示部分第三种:强制显示所有标签并旋转 第一种:竖排显示 xAxis: {type: category,data: res.data.data.sz.xAxis,axisLabel:{fontSize:12,formatter: function(value) {return value.split().joi…

gitlab安装以及创建用户创建组,修改密码 邮箱配置 数据备份与恢复--保姆级教学!

GitLab是一种基于Web的Git仓库管理工具,它允许您在组织或个人级别上创建和管理Git仓库,以便在一个中心位置上执行代码管理和协作工作。GitLab提供了强大的功能,如代码审查、问题跟踪、CI/CD、容器注册表、Wiki和持续集成等。 以下是GitLab的…

gitlab安装配置及应用

安装 ##安装依赖 yum install -y curl policycoreutils-python openssh-server perl#上传包 rz gitlab-jh-16.5.2-jh.0.el7.x86_64.rpm 安装 yum install gitlab-jh-16.0.3-jh.0.el7.x86_64.rpm 初始化并启动 # 以下两种方法都可以配置访问地址,第一种需要在yum安…

2023年【A特种设备相关管理(锅炉压力容器压力管道)】模拟考试题及A特种设备相关管理(锅炉压力容器压力管道)作业考试题库

题库来源:安全生产模拟考试一点通公众号小程序 A特种设备相关管理(锅炉压力容器压力管道)模拟考试题参考答案及A特种设备相关管理(锅炉压力容器压力管道)考试试题解析是安全生产模拟考试一点通题库老师及A特种设备相关…