Redis常用指令之string、list、set、zset、hash
Redis之五大类型常用指令
redis的一些小知识
-
redis服务器端口默认是6379
-
在编译完成后的bin目录下启动服务端:redis-server
-
客户端连接操作:redis-cli -h localhost -p 6379,如果是一台机器可以省略后面的:redis-cli
(备注:可以复制redis解压目录下的redis-conf文件到另一个文件夹,然后可以修改端口号 port 7000 这时你再次启动服务还是6379的端口号,读取的还是源码目录里的redis-conf文件,要想在启动的时候读取我们修改后的配置文件,需要修改启动命令的格式:redis-server 复制过来修改后的配置文件路径,比如:redis-server ./redis.conf 客户端启动的时候默认是与6379的端口号的redis服务连接,所有当我们指定端口号启动的时候,客户端也需要改变,格式为:redis-cli -h 服务器的ip地址 -p 端口号 ,比如:redis-cli -h localhost -p 7000)
-
redis 数据库默认有16个库,名字从0开始到15编号。一开始默认进入的是0号库。我们可以在客户端通过select dbid(库的编号)来切换库,比如:select 1 切换到1号库。同时需要注意的是库与库之间的数据是不共享的,是相对隔离的。
Redis特点
- Redis是一个高性能key/value内存型数据库,在redis中,所有的数据形式都是以键值对的方式来存储的
- Redis支持丰富的数据类型 string、list、set、sorted set 指的键值对中值的类型
- Redis支持持久化,将内存的数据存储到硬盘里面
- Redis单线程,单进程。由于是单线程和单进程的,所以它的线程是安全的。
操作key相关指令
-
del 指令
语法 : DEL key [key ...]
-
作用 : 删除给定的一个或多个key 。不存在的key 会被忽略。多个key之间使用空格隔开
-
可用版本: >= 1.0.0
-
返回值: 被删除key 的数量。
![image-20220812202950487]()
-
-
exists指令
语法: EXISTS key
-
作用: 检查给定key 是否存在。多个key之间使用空格隔开,只要有一个key存在,返回值就是1 新版本中会提示几个键存在
-
可用版本: >= 1.0.0
-
返回值: 若key 存在,返回1 ,否则返回0。
![image-20220812203100886]()
-
-
expire指令
语法: EXPIRE key seconds
-
作用: 为给定key 设置生存时间,以秒为单位,当key 过期时(生存时间为0 ),它会被自动删除。
-
可用版本: >= 1.0.0
-
时间复杂度: O(1)
-
返回值:设置成功返回1 。
![image-20220812203545532]()
-
-
keys指令
语法 : KEYS pattern
-
作用 : 查找所有符合给定模式pattern 的key 。
-
语法:
KEYS * 匹配数据库中所有key 。
KEYS h?llo 匹配hello ,hallo 和hxllo 等。
KEYS h*llo 匹配hllo 和heeeeello 等。
KEYS h[ae]llo 匹配hello 和hallo ,但不匹配hillo 。特殊符号用 "" 隔开 -
可用版本: >= 1.0.0
-
返回值: 符合给定模式的key 列表。
![image-20220812204021409]()
-
-
move指令
语法 : MOVE key db (move name 1----将name键移动到1号库)
-
作用 : 将当前数据库的key 移动到给定的数据库db 当中。
-
可用版本: >= 1.0.0
-
返回值: 移动成功返回1 ,失败则返回0 。
![image-20220812204203873]()
-
-
pexpire指令
语法 : PEXPIRE key milliseconds
-
作用 : 这个命令和EXPIRE 命令的作用类似,但是它以毫秒为单位设置key 的生存时间,而不像EXPIRE 命令那样,以秒为单位。
-
可用版本: >= 2.6.0
-
时间复杂度: O(1)
-
返回值:设置成功,返回1 key 不存在或设置失败,返回0
![image-20220812204416962]()
-
-
pexpireat指令
语法 : PEXPIREAT key milliseconds-timestamp
-
作用 : 这个命令和EXPIREAT 命令类似,但它以毫秒为单位设置key 的过期unix 时间戳,而不是像EXPIREAT那样,以秒为单位。
-
可用版本: >= 2.6.0
-
返回值:如果生存时间设置成功,返回1 。当key 不存在或没办法设置生存时间时,返回0 。(查看EXPIRE 命令获取更多信息)
![image-20220812205116949]()
-
-
ttl指令
语法 : TTL key
- 作用 : 以秒为单位,返回给定key 的剩余生存时间(TTL, time to live)。
- 可用版本: >= 1.0.0
- 返回值:
当key 不存在时,返回-2 。
当key 存在但没有设置剩余生存时间时,返回-1 。
否则,以秒为单位,返回key 的剩余生存时间。
-
pttl指令
语法 : PTTL key
-
作用 : 这个命令类似于TTL 命令,但它以毫秒为单位返回key 的剩余生存时间,而不是像TTL 命令那样,以秒为单位。
-
可用版本: >= 2.6.0
-
返回值: 当key 不存在时,返回-2 。当key 存在但没有设置剩余生存时间时,返回-1 。
-
否则,以毫秒为单位,返回key 的剩余生存时间。
![image-20220812205402121]()
-
-
randomkey指令
语法 : RANDOMKEY
-
作用 : 从当前数据库中随机返回(不删除) 一个key 。
-
可用版本: >= 1.0.0
-
返回值:当数据库不为空时,返回一个key 。当数据库为空时,返回nil 。
![image-20220812205608595]()
-
-
rename指令
语法 : RENAME key newkey
-
作用 : 将key 改名为newkey 。key 不存在时,返回一个错误。当newkey 已经存在时,RENAME 命令将覆盖旧值。
-
可用版本: >= 1.0.0
-
返回值: 改名成功时提示OK ,失败时候返回一个错误。
![image-20220812205936271]()
-
-
type指令
语法 : TYPE key
-
作用 : 返回key 所储存的值的类型。
-
可用版本: >= 1.0.0
-
返回值:
none (key 不存在)
string (字符串)
list (列表)
set (集合)
zset (有序集)
hash (哈希表)![image-20220812210850156]()
-
String类型操作命令

| 命令 | 说明 |
|---|---|
| set | 设置一个key/value |
| get | 根据key获得对应的value |
| mset | 一次设置多个key value |
| mget | 一次获得多个key的value |
| getset | 获得原始key的值,同时设置新值 |
| strlen | 获得对应key存储value的长度 |
| append | 为对应key的value追加内容 |
| getrange 索引0开始 | 截取value的内容 到末尾-1 |
| setex | 设置一个key存活的有效期(秒) |
| psetex | 设置一个key存活的有效期(毫秒) |
| setnx | 存在不做任何操作,不存在添加 |
| msetnx原子操作(只要有一个存在不做任何操作) | 可以同时设置多个key,只有有一个存在都不保存 |
| decr | 进行数值类型的-1操作 |
| decrby | 根据提供的数据进行减法操作 |
| Incr | 进行数值类型的+1操作 |
| incrby | 根据提供的数据进行加法操作 |
| Incrbyfloat | 根据提供的数据加入浮点数(不是四舍五入) |
-
set:设置一个key/value
-
get:根据key获得对应的value
-
mset:一次设置多个key/value
![image-20220812211520944]()
-
mget:一次获得多个key的value
![image-20220812211743926]()
-
getset:获得原始的key值,同时设置新值
![image-20220812211945225]()
-
strlen:获得对应key存储value的长度
![image-20220812212146850]()
-
append:为对应的key的value追加内容
![image-20220812212312067]()
-
getrange:截取value的内容,字符串的索引从0开始。比如12345从前往后数索引为01234,从后往前数索引为-1-2-3-4-5。所以截取到末尾可以用0 -1 表示。
![image-20220812212954215]()
-
setnx:key/value如果存在,不做任何操作,不存在添加
![image-20220812213214929]()
-
msetnx:原子操作(只要有一个存在不做任何操作)可以同时设置多个key,只有有一个存在都不保存
![image-20220812214413047]()
-
setex:设置一个key存活的有效期(秒),跟expire指令意思相同,但是这个指令还需要输入key对应的value
![image-20220812213858764]()
-
psetex:设置一个key存活的有效期(毫秒),跟pexpire指令意思相同,但是这个指令还需要输入key对应的value
-
decr:进行数值类型的-1操作
-
decrby:根据提供的数据进行减法操作
-
incr:进行数值类型的+1操作
-
incrby:根据提供的数据进行加法操作
-
incrbyfloat:根据提供的数据加入浮点数,不是四舍五入
![image-20220812214930025]()
List类型
ist 列表 相当于java中list 集合 特点 元素有序 且 可以重复,key还是一个字符串,值是一个list
1.内存存储模型

2.常用操作指令
| 命令 | 说明 |
|---|---|
| lpush | 将某个值加入到一个key列表头部 lpush list xiaohu xiaohei xiaoming 当列表不存在的时候会进行创建 |
| lpushx | 同lpush,但是必须要保证这个key存在 必须在列表进行存在的情况下从左插入 |
| rpush | 将某个值加入到一个key列表末尾 |
| rpushx | 同rpush,但是必须要保证这个key存在 |
| lpop | 返回和移除列表左边的第一个元素 |
| rpop | 返回和移除列表右边的第一个元素 |
| lrange | 获取某一个下标区间内的元素 lrange list 0 -1 |
| llen | 获取列表元素个数 |
| lset | 设置某一个指定索引的值(索引必须存在) |
| lindex | 获取某一个指定索引位置的元素 |
| lrem | 删除重复元素 |
| ltrim | 保留列表中特定区间内的元素 |
| linsert | 在某一个元素之前,之后插入新元素 |
-
lpush:(小写的L)将某个值加入到一个key列表头部 lpush list xiaohu xiaohei xiaoming 当列表不存在的时候会进行创建
![image-20220812220709188]()
-
lpushx:同lpush,但是必须要保证这个key存在 必须在列表进行存在的情况下从左插入
![image-20220812220906339]()
-
rpush:将某个值加入到一个key列表末尾
-
rpushx:同rpush,但是必须要保证这个key存在
![image-20220812221111014]()
-
lpop:返回和移除左列表左边的第一个元素,加上数字可以移除左边前几个元素
-
rpop: 返回和移除列表右边的第一个元素,加上数字可以移除右边后几个元素
-
lrange:获取某一个下标区间内的元素 lrange list 0 -1,和string类型的getrange命令意思一样
![image-20220812221539781]()
-
llen:获取列表元素个数
![image-20220812222146110]()
-
lset:设置某一个指定索引的值(索引必须存在)
-
lindex:获取某一个指定索引位置的元素
![image-20220812223457990]()
-
lrem:删除重复元素 。
![image-20220812223629164]()
![image-20220812223803297]()
-
ltrim:保留列表中特定区间内的元素
![image-20220812224457137]()
-
linsert:在某一个元素之前,之后插入新元素
![image-20220812224520177]()
![image-20220812224633594]()
Set类型
特点: Set类型 Set集合 元素无序 不可以重复
常用命令(如果set集合没有元素,key也就不存在了)
| 命令 | 说明 |
|---|---|
| sadd | 为集合添加元素 |
| smembers | 显示集合中所有元素 无序 |
| scard | 返回集合中元素的个数 |
| spop | 随机返回一个元素 并将元素在集合中删除 |
| smove | 从一个集合中向另一个集合移动元素 必须是同一种类型 |
| srem | 从集合中删除一个元素 |
| sismember | 判断一个集合中是否含有这个元素 |
| srandmember | 随机返回元素 后面可以加数字 表示每次返回的个数 |
| sdiff | 去掉第一个集合中其它集合含有的相同元素 |
| sinter | 求交集 |
| sunion | 求和集 |
-
sadd:为集合添加元素
-
smembers:显示集合中所有元素,无序
-
scard:返回集合中的个数
![image-20220816095743001]()
-
spop:返回集合中的count个元素,并在集合中删除
![image-20220816100118959]()
-
smove:从一个集合向另一个集合移动元素,必须是同一种集合类型,移动元素要带引号不然集合中的值虽然移动了,但是原来的值的位置还在
![image-20220816100838257]()
-
srem:从集合中删除一个或多个元素
-
sismember:判断一个集合中是否含有这个元素
![image-20220816101235070]()
-
srandmember:随机返回数据,后面可以加数字表示返回的个数
-
sdiff:去掉一个集合中其他集合含有的相同元素(求差集)
-
sinter:求交集
-
sunion:求合集
![image-20220816103525171]()
ZSet集合
特点: 可排序的set集合 排序 不可重复
ZSET 官方 可排序SET sortSet
常用命令
| 命令 | 说明 |
|---|---|
| zadd | 添加一个有序集合元素 zadd zset 2 xiaohu 3 xiaohu2 |
| zcard | 返回集合的元素个数 |
| zrange 升序 zrevrange 降序 | 返回一个范围内的元素 如果想看看分数 withscores |
| zrangebyscore(6.2.0版本后已弃用) | 按照分数查找一个范围内的元素 zrangebyscore zset 0 20 withscores limit 0 2 |
| zrank | 返回排名 |
| zrevrank | 倒序排名 |
| zscore | 显示某一个元素的分数 |
| zrem | 移除某一个元素 |
| zincrby | 给某个特定元素加分 |
-
zadd:添加一个有序集合元素
-
zcard: 返回集合的元素个数
-
zrange 升序 zrevrange 降序:返回一个范围内的元素 如果想看看分数 withscores
范围是集合的索引,左闭右闭
![image-20220816104622878]()
-
zrangebyscore:按照分数查找一个范围内的元素
![image-20220816111017276]()
![image-20220816111045329]()
按照分数查询,同时设置按索引范围查询
![image-20220816112247929]()
![image-20220816112301607]()
-
zrank:返回排名
-
zrevrank:倒序排名
-
zscore:显示某一个元素的分数
-
zrem:移除某一个元素
-
zincrby:给某个特定元素加分
![image-20220816111743475]()
hash类型
特点: value 是一个map结构 存在key value key 无序的
redis key(String) value(map)
Map<String,Map<String,value>> map
举例:map name zhangsan

常用命令
| 命令 | 说明 |
|---|---|
| hset | 设置一个、多个key/value对 |
| hget | 获得一个key对应的value |
| hgetall | 获得所有的key/value对 |
| hdel | 删除某一个key/value对 |
| hexists | 判断一个key是否存在 |
| hkeys | 获得所有的key |
| hvals | 获得所有的value |
| hmset(已弃用) | 设置多个key/value |
| hmget | 获得多个key的value |
| hsetnx | 设置一个不存在的key的值 |
| hincrby | 为value进行加法运算(只能针对数值做运行) |
| hincrbyfloat | 为value加入浮点值 |
-
hset:设置一个key/value对,可设置多个,设置中文显示不出来,可通过可视化工具查看
![image-20220816143347833]()
![image-20220816144329333]()
![image-20220816144342517]()
-
hget、hmget:获得一个key的value、获得多个key的value
![image-20220816143552148]()
-
hkeys、hvals:获得所有的key、获得所有的value
**
















































**
浙公网安备 33010602011771号