| expire key 10 | 设置key地存活时间,单位秒 |
| ttl key | 查看还有多少秒过期,-1表示用不过期,-2表示已过期 |
| set key value | 添加键值对 |
数据库相关操作
命令 | 作用 |
---|---|
select 1 | 切换到数据库1 |
dbsize | 查看当前数据库地key |
flushdb | 清空当前库 |
flushall | 通杀全部库 |
redis一共有16个数据库,默认使用的是0号数据库
Redis字符串(String)
String是redis最基本的数据类型,
String类型是二进制安全的,Redis的string可以包含任何数据,如图片。序列化的对象
String 类型是Redis最基本的数据类型,一个Redis中字符value最多可以是512M
字符串的常用命令
set key value
添加键值对
# 清空数据库
flushdb
# 查看数据库中的键
keys \*
#添加新数据
set k1 100
set k2 200
set k3 300
get key
取值
get k1
append key value
在原有得值后面追加新的内容
# 在键为text的值的后面添加world
append text world
setnx key value
只有在键不存在的时候可以设置值,能够避免覆盖的情况
incr key
对于整数,会自增1
decr key
对于整数 会减1
对k1自增或者自减
设置自增或自减步长
incrby key increment
decrby key increment
# 设置k1的值自增100
incrby k1 100
mset key1 value1 key2 value2 ...
同时设置多个键值对
mget key1 key2 ...
同时获取多个键值对
同时设置多个数据库中不存在的键值对,如果其中一个键存在,则所有的内容都不会被创建成功
msetnx key1 value1 key2 value2 …
strlen key
获取字符串的长度
getrange key start end
遍历输出
getrange name 0 -1
获取第一个字符第3个字符
getrange name 0 2
setrange key 开始位置 value
用新的值覆盖旧值
setex key 过期时间 value
设置值得同时设置过期时间,单位为秒
# 过期时间20秒 值为v1
setex k5 20 v1
获取旧得值填充新的值
getset key value
getset k1 33
字符串的数据结构
String的数据结构为简单动态字符串(Simple Dynamic String)是可以修改的字符串,内部的实现结构和python中的list
类似,都是先预先分配一些空间,当空间不够用会自动扩充空间的大小,最大长度为512M
Redis列表(List)
Redis列表是简单的字符串列表,按照插入顺序排序,你可以添加应给元素到表头或者尾
它的底部实际是个双向链表,对两端的操作性性能很高,通过索引下标的操作中间节点的性能较差。
列表常用命令
lpush/rpush key value1 value2 value3
从左边/右边插入一个或者多个值lpop/rpop key
从左边/右边弹出一个值 值在键在,键光键亡rpoplpush key1 key2
从key1列表右边弹出一个值,插入到key2列表的左边lrange key start stop
按照索引下标获得元素(从左到右)
代码演示
lindex key index
按照索引下标获得元素llen key
获取列表的长度
linsert key before value newvalue
在value的前面插入newvalue
在3的前面插入99
linsert k1 before 3 99
在99的后面插入55
linsert k1 after 99 55
lrem key n value
从左边删除n个value(删除重复值)
删除k4列表中左面3个2
lpush k4 1 2 2 3 2 1 5 2
lrem k4 3 2
lrange k4 0 -1
lset key index value
将列表key下标为index的值替换成value
lpush k5 1 2 3 4 5
# 将索引为2的值替换成22
lset k5 2 22
# 将索引为3的值替换成44
lset k5 3 44
列表的数据结构
list的数据结构是快速链表
首先在列表元素较少的情况下会使用一块连续的内存存储,这个结构是ziplist压缩列表,所有的元素在一块连续的内存空间
元素较多时,才会改成quicklist,
quicklist是将多个ziplist用双向链表的形式链接起来的数据结构
Redis 集合(Set)
是一个无序不重复的序列,集合成员是唯一的
操作类似于list
底层是一个value为null的hash表,添加,删除,查找的复杂度都是O(1)
集合的常用命令
sadd key value1 value2 ...
将元素添加到集合key中,如果新添加的元素已经在集合中存在,则会被忽略
# 向s1集合中添加元素
sadd s1 1 2 3 4 4 4
smembers key
取出该集合的所有值
# 查看s1中的集合
smembers s1
sismember key value
判断集合中是否存在该值 有返回1 没有返回0
sadd s2 1 2 3 4 5
sismember s2 2 # 返回1
sismember s2 6 # 返回0
scard key
返回集合的个数
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
片转存中…(img-StZZOpBq-1714421624845)]
[外链图片转存中…(img-ok5ZTWjg-1714421624845)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!