怎么使用mysql模拟redis
来源:亿速云
时间:2023-04-27 15:20:48 469浏览 收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《怎么使用mysql模拟redis》,聊聊,我们一起来看看吧!
Redis是文本协议
redis
是文本协议,协议名称叫做RESP
。RESP
是 Redis
序列化协议的简写。它是一种直观的文本协议,优势在于实现异常简单,解析性能极好。
如图,Redis
协议将传输的结构数据,可以总结为 5 种最小单元类型。每个单元结束时,统一加上回车换行符号 \r\n 。
下面是几个规则:
单行字符串 以 + 开头; 多行字符串 以 $ 开头,后跟字符串长度; 整数值 以 : 开头,后跟整数的字符串形式; 错误消息 以 - 符号开头; 数组 以 * 号开头,后跟数组的长度;
比如,下面这个就是数组[9,9,6]的报文。
*3\r\n:9\r\n:9\r\n:6\r\n
所以这个协议的解析和拼装,是非常简单的。拿netty
来说,就有codec-redis 模块供我们使用。
实现:数据结构设计
在数据表的设计上,我们发现,kv
和hash
在效率上没有什么差别,因为它能够直接根据key
定位到。
反倒是zset
,由于有排序的功能,造成了很多操作的执行效率都不尽人意。
另外,由于我们不同的数据结构,是使用不同的表进行存储的。所以删除操作,要在每张表上都执行一遍。
kv设计
kv
,即string
,是redis
里最基本的数据类型。一个key
对应一个value
,string
类型的值最大能存储512MB。
设计专用的数据库表rstore_kv
,其中,rkey
是主键。
rkey varchar val varchar lastTime bigint
set操作
insert into rstore_kv("rkey","val","lastTime") values($1,$2,$3) on duplicate key update set "val"=$2,"lastTime"=$3
get操作
select val from rstore_kv where "rkey" = $1
del操作
delete from rstore_kv where "rkey" = $1
exists操作
select count(*) as n from rstore_kv where "rkey" = $1
ttl操作
select lastTIme from rstore_kv where "rkey" = $1
hash设计
hash
是一个键值(key=>value)对集合。hash
特别适合用于存储对象。
设计专用的数据库表rstore_hash
,其中,rkey
和hkey
是联合主键。
rkey varchar hkey varchar val varchar lastTime bigint
hset操作
insert into rstore_hash("rkey","hkey","val","lastTime") values($1,$2,$3,$4) on duplicate key update set "val"=$3,"lastTime"=$4
hget操作
select val from rstore_hash where "rkey" = $1 and "hkey" = $2
hgetall操作
select hkey,val from rstore_hash where "rkey" = $1
hdel操作
delete from rstore_hash where "rkey" = $1 and "hkey" = $2
del操作
delete from rstore_hash where "rkey" = $1
hlen,hexists操作
select count(*) as num from rstore_hash where "rkey" = $1
ttl操作
select max(lastTIme) from rstore_hash where "rkey" = $1
zset设计
Redis zset
和 set
一样也是string
类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double
类型的分数。redis
正是通过分数来为集合中的成员进行从小到大的排序。它的底层结构是跳跃表,效率特别高,但是会占用大量内存。
设计专用的数据库表rstore_zset
,其中,rkey
和member
是联合主键。
rkey varchar member varchar score double lastTime bigint
zadd操作
insert into rstore_zset("rkey","member","score","lastTime") values($1,$2,$3,$4) on duplicate key update update set "score"=$3,"lastTime"=$4
zscore操作
select score from rstore_zset where "rkey" = $1 and "member" = $2
zrem操作
delete from rstore_zset where "rkey" = $1 and "member" = $2"
zcard,exists操作
select count(*) as num from rstore_zset where "rkey" = $1
zcount操作
select count(*) as num from rstore_zset where "rkey" = $1 and score>=$2 and scorezremrangebyscore操作
delete from rstore_zset where "rkey" = $1 and score>=$2 and scorezrangebyscore操作
select member,score from rstore_zset where "rkey" = $1 and score>=$2 and scorezrange操作
select member,score from rstore_zset where "rkey" = $1 order by score asc offset $2 limit $3zrank操作
select rank from (select member,rank() over (order by "score" asc, "lastTime" asc) as rank from rstore_zset where "rkey" = $1 ) m where m."member"= $2;ttl操作
select max(lastTIme) from rstore_zset where "rkey" = $1del操作
delete from rstore_zset where "rkey" = $1set设计
Redis
的Set
是string
类型的无序集合。设计专用的数据库表
rstore_set
,其中,rkey
和member
是联合主键。rkey varchar member varchar lastTime bigintsadd操作
insert into rstore_set("rkey","member","lastTime") values($1,$2,$3) on duplicate key update update set "lastTime"=$3scard操作
select count(*) as num from rstore_set where "rkey" = $1sismember操作
select member from rstore_set where "rkey" = $1 and "member" = $2smembers操作
select member from rstore_set where "rkey" = $1srem操作
delete from rstore_set where "rkey" = $1 and "member" = $2del操作
delete from rstore_set where "rkey" = $1ttl操作
select max(lastTIme) from rstore_set where "rkey" = $1以上就是《怎么使用mysql模拟redis》的详细内容,更多关于mysql,redis的资料请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
297 收藏
-
483 收藏
-
416 收藏
-
335 收藏
-
208 收藏
-
170 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习