【快速掌握】Redis 的五种数据类型
不同于MySQL的表结构所带来的复杂语句,Redis只需要维护好它的【key-value】结构就可以,因此相比于MySQL,语句非常简单。
今天介绍一下Redis 五种常用的数据类型:

这五种数据类型对应五种【key-value】结构:分别是String\Hash\List\Set\SorceSet
字符串类型String
- 1.String类型既可以保存普通文字,也可以保存序列化的二进制数据
- 2.最大可以存储512M数据,一般足够我们使用
字符串类型语句
1.【SET KEY_NAME VALUE】本条语句用于创建一个字符串类型的数据,如果key已经存储了其他值,SET就覆盖旧值。

2.【GET KEY_NAME】本条语句用于查看数据内容,如果 key 不存在,返回 null 。如果key 储存的值不是字符串类型,返回一个错误。

3.【GETRANGE KEY_NAME INDEX1 INDEX2】本条语句用于查看某个范围内的数据内容,截取范围由start和end两个转换量决定(包括start和end在内)。

4.【STRLEN KEY_NAME】本条语句用于获得数据的长度,当密钥存储的不是字符串值时,返回一个错误。

5.【DEL KEY_NAME】本条语句用于删除数据

6.【SETEX KEY_NAME TIME VALUE】本条语句用于设置具有生命周期的数据,数据在经过一段时间后自动销毁,单位是秒

7.【MSET KEY_NAME_1 VALUE KEY_NAME_2 VALUE……】本条语句用于创建多条数据

8.【MGET KEY_NAME KEY_NAME_1 KEY_NAME_2】本条语句用于查看多条数据

9.【APPEND KEY_NAME VALUE】本条语句用于在某条数据后面追加内容

10.【INCR num 】数字自增加1,注意:针对的是整数

11.【INCRBY】数字自增加任意整数,注意:针对的是整数

12.【INCRBYFLOAT 】数字自增加任意小数

13.【DECR 】数字自减少1,注意:针对的是整数
14.【DECRBY 】数字自减少任意整数5,注意:针对的是整数
15.【注意:没有DECRBYFLOAT 这种语法,但是可以通过INCRBYFLOAT 增加一个负数变通实现】


哈希数据类型Hash
- Hash类型用于保存字典类型的数据
哈希类型语句
1.【HSET KEY_NAME key value】设置哈希字段
2.【HGET KEY_NAME key】查看哈希字段值

3.【HMSET KEY_NAME key_1 value key_2 value】设置多个哈希字段
4.【HMGET KEY_NAME key_1 key_2】查看多个哈希字段值

5.【HGETALL KEY_NAME】查看哈希字典中所有的key和value
6.【HKEYS KEY_NAME】查看所有哈希字段key
7.【HVALS KEY_NAME】查看所有哈希字段值value

8.【HLEN】查看所有哈希字段数量
9.【HEXISTS KEY_NAME key】判断哈希字典中是否存在某个字段key
9.【HINCRBY】让某个哈希字段的值加上指定的整数
10.【HINCRBYFLOAT】让某个哈希字段的值加上指定的小数


列表数据类型List
- list类型可以用于保存序列化数据
列表类型语句
1.【LPUSH】如果列表不存在,则创建一个列表并从左向右向里添加数据
2.【RPUSH】如果列表不存在,则创建一个列表并从右向左向里添加数据
3.【LRANGE】查看列表中某个范围内的数据(0 -1 表示从第0个到最后一个)

4.【LINSERT BEFORE/AFTER】在某个位置插入元素

5.【LSET key index value】替换列表中的某个数据

6.【LLEN】获得列表长度
7.【LINDEX】获得列表中某个索引下的元素

8.【LPOP】删除列表中最左边的元素,并返回该元素
9.【RPOP】删除列表中最右边的元素,并返回该元素

10.【LREM】删除列表中的某个元素


集合数据类型Set
- 如果要保存的数据不允许重复,可以使用集合类型
集合类型语句
1.【SADD KEY_NAME VALUE】
Redis Sadd命令将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。假如集合键不存在,则创建一个只包含添加的元素作成员的集合。当集合键不是集合类型时,返回一个错误。
2.【SMEMBERS】查看集合中的所有数据

3.【SCARD】获得集合长度
4.【SISMEMBER】判断是否含有某个元素
5.【SREM】删除元素

6.【SPOP】随机删除集合中某个元素,并返回该元素
7.【SRANDMEMBER】随机返回某个元素


有序集合数据类型ZSet
- 有序集合是带有排序功能的集合,Redis可以根据分数值对元素进行排序
有序集合类型语句
1.【ZADD KEY_NAME SCORE1 VALUE1.. SCOREN VALUEN】
Zadd 命令用于将一个或多个成员元素及其分数值加入到有序集当中。如果某个成员已经是有序集的成员,那么更新这个成员的分数值,并通过重新插入这个成员元素,来保证该成员在正确的位置上。分数值可以是整数值或双精度浮点数。如果有序集合 key 不存在,则创建一个空的有序集并执行 ZADD 操作。当 key 存在但不是有序集类型时,返回一个错误。
2.【ZINCRBY KEY_NAME INCREMENT MEMBER】
Zincrby命令对有序集合中指定成员的分数附加增量,可以通过传递一个负数值增量,当key不存在,或分数不是key的成员时,ZINCRBY key递增成员等效于ZADD key递增成员。当key不是有序集类型时,返回一个错误。分数值可以是整数值或双精度浮点数。
3.【ZREVRANGE KEY_NAME start stop】
返回指定区间内的成员,按照分数值进行降序排列,具有相同分数值的成员按字典序的逆序(reverse lexicographical order)排列。

4.【ZCARD】获得有序集合的长度
5.【ZCOUNT】查询某个分数区间内的元素数量
6.【ZSCORE】查询某个元素的分数值

7.【ZRANGE KEY_NAME start stop [withscores]】查询某个范围内的集合元素,升序
8.【ZREVRANGE KEY_NAME start stop [withscores]】查询某个范围内的集合元素,降序

9.【ZRANGEBYSCORE】获得分数值区间内的元素,升序
10.【ZREVRANGESCORE】获得分数值区间内的元素,降序

11.【ZREM】删除有序集合中的元素

12.【ZREMRANGEBYRANK】删除排名区间内的元素

13.【ZREMRANGEBYSCORE】删除分数值区间内的元素

That`s all !
【快速掌握】Redis 的五种数据类型的更多相关文章
- Redis: Redis支持五种数据类型
ylbtech-Redis: Redis支持五种数据类型 Redis支持五种数据类型:string(字符串) ,hash(哈希),list(列表),set(集合)及zset(sorted set:有序 ...
- Redis的五种数据类型的简单介绍和使用
1.准备工作: 1.1在Linux下安装Redis https://www.cnblogs.com/dddyyy/p/9763098.html 1.2启动Redis 先把root/redis的red ...
- redis的五种数据类型及应用场景
前言 redis是用键值对的形式来保存数据,键类型只能是String,但是值类型可以有String.List.Hash.Set.Sorted Set五种,来满足不同场景的特定需求. 本博客中的示例不是 ...
- [Redis]Redis的五种数据类型与键值/服务器相关命令
-------------------------------------------------------------------------------------- String(字符串):最 ...
- StackExchange.Redis学习笔记(二) Redis查询 五种数据类型的应用
ConnectionMultiplexer ConnectionMultiplexer 是StackExchange.Redis的核心对象,用这个类的实例来进行Redis的一系列操作,对于一个整个应用 ...
- Redis的五种数据类型及方法
字符串string: 字符串类型是Redis中最为基础的数据存储类型,是一个由字节组成的序列,他在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据货Json对象描 ...
- Redis的五种数据类型
官方的几篇很好的文章: https://redis.io/topics/data-types https://redis.io/topics/data-types-intro https://redi ...
- Redis:五种数据类型的简单增删改查
Redis简单增删改查例子 例一:字符串的增删改查 #增加一个key为ay_key的值 127.0.0.1:6379> set ay_key "ay" OK #查询ay_ke ...
- Redis探索之路(四):Redis的五种数据类型Set和ZSet
一:Set无需集合 Set是个集合,string类型的无需集合,通过hash table实现,添加删除查找复杂度都是0(1).对集合我们可以取并集,交集和差集.通过这些操作我们可以实现sns中的好友推 ...
随机推荐
- Postman 的 Post 请求方式的四种类型的数据
Postman 的 Post 请求方式的四种类型的数据 1. form-data 2. x-www-form-urlencoded 3. raw 4. binary 1. form-data 就是 H ...
- servelet 实现Post接口访问
先上代码: package com.jovtec.galaxy.mailbox; import java.io.BufferedReader; import java.io.IOException; ...
- Flink-v1.12官方网站翻译-P013-Timely Stream Processing
及时的流处理 介绍 及时流处理是有状态流处理的一种扩展,其中时间在计算中起着一定的作用.其中,当你做时间序列分析时,当做基于某些时间段(通常称为窗口)的聚合时,或者当你做事件处理时,事件发生的时间很重 ...
- Yacc使用优先级
Yacc使用优先级 本示例是龙书4.9.2的示例,见图4-59. 和前一章一样,新建xUnit项目,用F#语言.起个名C4F59安装NuGet包: Install-Package FSharpComp ...
- Inceptor [Code: 40000, SQL State: 42000] COMPILE FAILED: Internal error NullPointerException: [Error 40000] java.lang.NullPointerException
下面代码报空指针 with `__all_dim__` as ( select * from ( select from_unixtime(unix_timestamp(`__bts__`) -1,' ...
- 2019牛客多校 Round7
Solved:5 Rank:296 E Find the median (线段树) 题意:最开始一个空的数组 4e5次操作 每次把Li,Ri中的每个数插入进来 问当前的中位数 题解:把这n个区间离散化 ...
- o2,o3优化
#pragma GCC optimize(2)//O2优化 #pragma GCC optimize(3,"Ofast","inline")//O3优化
- 【uva 1151】Buy or Build(图论--最小生成树+二进制枚举状态)
题意:平面上有N个点(1≤N≤1000),若要新建边,费用是2点的欧几里德距离的平方.另外还有Q个套餐,每个套餐里的点互相联通,总费用为Ci.问让所有N个点连通的最小费用.(2组数据的输出之间要求有换 ...
- 【noi 2.6_9284】盒子与小球之二(DP)
题意:有N个有差别的盒子和分别为A个和B个的红球和蓝球,盒子内可空,问方案数. 解法:我自己打的直接用了求组合C的公式,把红球和蓝球分开看.对于红球,在N个盒子可放任意个数,便相当于除了A个红球还有N ...
- Codeforces Round #667 (Div. 3) C. Yet Another Array Restoration (数学)
题意:给你两个数字\(x\)和\(y\),让你构造一个长度为\(n\)的序列,要求包含\(x\)和\(y\),并且排序后相邻两项的差值相等. 题解:有排序后相邻两项的差值相等可知,构造的序列排序后一定 ...