redis入门到精通系列(一)
(一)为什么要用Nosql
如果你是计算机本科学生 ,那么一定使用过关系型数据库mysql。在请求量小的情况下,使用mysql不会有任何问题,但是一旦同时有成千上万个请求同时来访问系统时,就会出现卡顿甚至系统崩溃的情况。最典型的例子就是早期的12306购票网站,一旦到了购票高峰期,12306肯定崩溃。造成这个原因的罪魁祸首就是关系型数据库。
为了解决这两个问题,非关系型数据库出现了,非关系型数据库有两个特点:
(二)redis介绍
Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,他有如下几个特征:
4.多数据类型支持:字符串类型(string)、列表类型(list)、散列类型(hash)、集合类型(set)、有序集合类型(sorted_set)
Redis的应用场景也非常广泛,如热点新闻、购票抢票、即时信息查询、时效性信息控制、消息队列、分布式锁等等。
(三)redis数据类型操作
介绍完nosql和redis后就开始正式操作redis了,确保你此时已经下载安装redis服务,并且已经打开服务。
3.1 string类型
set key value
get key
del key
添加修改多个数据
mset key1 value1 key2 value2 ...
mget key1 key2...
strlen key
append key value
多操作指令看上去似乎是对单操作指令的简单相加,但其实不然。一条指令执行有三个地方需要耗时:发送指令、处理指令、返回结果。当使用多操作指令的时候,发送和返回都只执行一次,相比较多次只从单操作指令减少了大笔时间。
incr key
incrby key increment
incrbtfloat key increment
decr key
decrby key increment
setex key seconds value
psetex key milliseconds value
以上就是string类型的语法操作,对于key值的命名规范也有指定的约定,比如对于一个微博大V的粉丝数,微博数,关注数可以用下面的方法命名:
user:id:123456:fans
user:id:123456:blogs
user:id:123456:focus
3.2hash类型
hash类型主要用于在一个存储空间内保存多个键值对信息。比如上面微博的三项基本数据,如果按照上面的方式就需要三条数据,这里就可以中hash存储。
hset key field value
hget key field
hgetall key
hdel key field
hmset key field1 value1 field2 value2...
hmget key field1 field2
hlen key
hexists key field
hkeys key
hvals key
hincrby key field increment
hincrbyfloat key field increment
hash类型的操作至此也结束了,需要注意的是,hash类型下的value只能存储字符串,不允许存储其他数据类型,不存在嵌套现象。每个hash可以存储2^32-1个键值对。
3.3 list类型
list类型数据用于存储多个数据,并对数据进入存储空间的顺序进行区分。list类型的数据可以保存多个数据,底层使用双向链表存储结构实现。
既然是双向链表的方式实现,那么就可以从左右两边添加和修改数据,下面是具体操作
lpush key value1 value2...
rpush key value1 value2...
lrange key start stop (stop=-1时表示最后一个元素)
lindex key index
llen key
lpop key
rpop key
blpop key1 key2 timeout
brpop key1 key2 timeout
这条命令的意思是当列表中没有元素时,会等待timeout指定的时间,期间一旦有数据加入到List列表中,就会显示出来,否则时间到了后就显示为空。
lrem key count value
3.4 set类型
set类型与hash存储结构完全相同,不同点在于,set仅存储键,不存储值,并且值不允许为空。
添加数据
sadd key member1 member2...
smembers key
srem key member1 member2...
scard key
sismember key member
srandmember key [count]
spop key
sinter key1 key2 ..
sunion key1 key2 ..
sdiff key1 key2 ..
sinterstore destination key1 key2 ..
sunionstore destination key1 key2 ..
sdiffstore destination key1 key2 ..
smove source destination member
set的操作到这里就结束了,要注意set类型的数据不允许重复,且set虽然与hash存储结构相同,但是无法启用hash中的存储空间
3.5 sorted_set类型
sorted_set在set的基础上添加了可排序字段,使得存储可按可排序字段来排序,这个可排序字段称为score。
zadd key score1 member1 score2 member2 ...
zrange key start stop [withscores]
zrevrange key start stop [withscores]
zrem key member1 member2...
zrangebyscore key min max [withscores] [limit]
zrevrangebyscore key max min [withscores]
zremrangebyrank key start stop
zremrangebyscore key min max
zcard key
zcount key min max
zinterstore destination numkeys key1 key2...(求交集,默认求出score的和,可以修改为最大值最小值等等)
zunionstore destination numkeys key1 key2...
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了