这篇文章主要介绍“怎么使用mysql模拟redis”,在日常操作中,相信很多人在怎么使用mysql模拟redis问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用mysql模拟redis”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

Redis是文本协议

redis是文本协议,协议名称叫做RESPRESPRedis 序列化协议的简写。它是一种直观的文本协议,优势在于实现异常简单,解析性能极好。

如图,Redis 协议将传输的结构数据,可以总结为 5 种最小单元类型。每个单元结束时,统一加上回车换行符号 \r\n 。

下面是几个规则:

单行字符串以+开头;多行字符串以$开头,后跟字符串长度;整数值以:开头,后跟整数的字符串形式;错误消息以-符号开头;数组以*号开头,后跟数组的长度;

比如,下面这个就是数组[9,9,6]的报文。

*3\r\n:9\r\n:9\r\n:6\r\n

所以这个协议的解析和拼装,是非常简单的。拿netty来说,就有codec-redis 模块供我们使用。

实现:数据结构设计

在数据表的设计上,我们发现,kvhash在效率上没有什么差别,因为它能够直接根据key定位到。

反倒是zset,由于有排序的功能,造成了很多操作的执行效率都不尽人意。

另外,由于我们不同的数据结构,是使用不同的表进行存储的。所以删除操作,要在每张表上都执行一遍。

kv设计

kv,即string,是redis里最基本的数据类型。一个key对应一个valuestring类型的值最大能存储512MB。

设计专用的数据库表rstore_kv,其中,rkey是主键。

rkeyvarcharvalvarcharlastTimebigint

set操作

insertintorstore_kv("rkey","val","lastTime")values($1,$2,$3)onduplicatekeyupdateset"val"=$2,"lastTime"=$3

get操作

selectvalfromrstore_kvwhere"rkey"=$1

del操作

deletefromrstore_kvwhere"rkey"=$1

exists操作

selectcount(*)asnfromrstore_kvwhere"rkey"=$1

ttl操作

selectlastTImefromrstore_kvwhere"rkey"=$1hash设计

hash 是一个键值(key=>value)对集合。hash 特别适合用于存储对象。

设计专用的数据库表rstore_hash,其中,rkeyhkey是联合主键。

rkeyvarcharhkeyvarcharvalvarcharlastTimebigint

hset操作

insertintorstore_hash("rkey","hkey","val","lastTime")values($1,$2,$3,$4)onduplicatekeyupdateset"val"=$3,"lastTime"=$4

hget操作

selectvalfromrstore_hashwhere"rkey"=$1and"hkey"=$2

hgetall操作

selecthkey,valfromrstore_hashwhere"rkey"=$1

hdel操作

deletefromrstore_hashwhere"rkey"=$1and"hkey"=$2

del操作

deletefromrstore_hashwhere"rkey"=$1

hlen,hexists操作

selectcount(*)asnumfromrstore_hashwhere"rkey"=$1

ttl操作

selectmax(lastTIme)fromrstore_hashwhere"rkey"=$1zset设计

Redis zsetset 一样也是string类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。它的底层结构是跳跃表,效率特别高,但是会占用大量内存。

设计专用的数据库表rstore_zset,其中,rkeymember是联合主键。

rkeyvarcharmembervarcharscoredoublelastTimebigint

zadd操作

insertintorstore_zset("rkey","member","score","lastTime")values($1,$2,$3,$4)onduplicatekeyupdateupdateset"score"=$3,"lastTime"=$4

zscore操作

selectscorefromrstore_zsetwhere"rkey"=$1and"member"=$2

zrem操作

deletefromrstore_zsetwhere"rkey"=$1and"member"=$2"

zcard,exists操作

selectcount(*)asnumfromrstore_zsetwhere"rkey"=$1

zcount操作

selectcount(*)asnumfromrstore_zsetwhere"rkey"=$1andscore>=$2andscore<=$3

zremrangebyscore操作

deletefromrstore_zsetwhere"rkey"=$1andscore>=$2andscore<=$3

zrangebyscore操作

selectmember,scorefromrstore_zsetwhere"rkey"=$1andscore>=$2andscore<=$3orderbyscoreasc,memberasc

zrange操作

selectmember,scorefromrstore_zsetwhere"rkey"=$1orderbyscoreascoffset$2limit$3

zrank操作

selectrankfrom(selectmember,rank()over(orderby"score"asc,"lastTime"asc)asrankfromrstore_zsetwhere"rkey"=$1)mwherem."member"=$2;

ttl操作

selectmax(lastTIme)fromrstore_zsetwhere"rkey"=$1

del操作

deletefromrstore_zsetwhere"rkey"=$1set设计

RedisSetstring类型的无序集合。

设计专用的数据库表rstore_set,其中,rkeymember是联合主键。

rkeyvarcharmembervarcharlastTimebigint

sadd操作

insertintorstore_set("rkey","member","lastTime")values($1,$2,$3)onduplicatekeyupdateupdateset"lastTime"=$3

scard操作

selectcount(*)asnumfromrstore_setwhere"rkey"=$1

sismember操作

selectmemberfromrstore_setwhere"rkey"=$1and"member"=$2

smembers操作

selectmemberfromrstore_setwhere"rkey"=$1

srem操作

deletefromrstore_setwhere"rkey"=$1and"member"=$2

del操作

deletefromrstore_setwhere"rkey"=$1

ttl操作

selectmax(lastTIme)fromrstore_setwhere"rkey"=$1

到此,关于“怎么使用mysql模拟redis”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!