Inhaltsverzeichnis
Redis是文本协议
实现:数据结构设计
kv设计
hash设计
zset设计
set设计
Heim Datenbank MySQL-Tutorial So simulieren Sie Redis mit MySQL

So simulieren Sie Redis mit MySQL

Jun 01, 2023 pm 03:13 PM
mysql redis

Redis是文本协议

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

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

下面是几个规则:

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

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

*3\r\n:9\r\n:9\r\n:6\r\n
Nach dem Login kopieren

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

实现:数据结构设计

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

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

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

kv设计

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

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

rkey        varchar
val     varchar
lastTime    bigint
Nach dem Login kopieren

set操作

insert into rstore_kv("rkey","val","lastTime") values($1,$2,$3)
on duplicate key update set "val"=$2,"lastTime"=$3
Nach dem Login kopieren

get操作

select val from rstore_kv where "rkey" = $1
Nach dem Login kopieren

del操作

delete from rstore_kv where "rkey" = $1
Nach dem Login kopieren

exists操作

select count(*) as n from rstore_kv where  "rkey" = $1
Nach dem Login kopieren

ttl操作

select lastTIme from rstore_kv  where  "rkey" = $1
Nach dem Login kopieren

hash设计

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

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

rkey        varchar
hkey        varchar
val     varchar
lastTime    bigint
Nach dem Login kopieren

hset操作

insert into rstore_hash("rkey","hkey","val","lastTime") values($1,$2,$3,$4)
on duplicate key update set "val"=$3,"lastTime"=$4
Nach dem Login kopieren

hget操作

select val from rstore_hash where "rkey" = $1 and "hkey" = $2
Nach dem Login kopieren

hgetall操作

select hkey,val from rstore_hash where "rkey" = $1
Nach dem Login kopieren

hdel操作

delete from rstore_hash where "rkey" = $1 and "hkey" = $2
Nach dem Login kopieren

del操作

delete from rstore_hash where "rkey" = $1
Nach dem Login kopieren

hlen,hexists操作

select count(*) as num from rstore_hash where "rkey" = $1
Nach dem Login kopieren

ttl操作

select max(lastTIme) from rstore_hash  where  "rkey" = $1
Nach dem Login kopieren

zset设计

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

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

rkey        varchar
member        varchar
score     double
lastTime    bigint
Nach dem Login kopieren

zadd操作

insert into rstore_zset("rkey","member","score","lastTime") values($1,$2,$3,$4) on duplicate key update update set "score"=$3,"lastTime"=$4
Nach dem Login kopieren

zscore操作

select score from rstore_zset where "rkey" = $1 and "member" = $2
Nach dem Login kopieren

zrem操作

delete from rstore_zset where "rkey" = $1 and "member" = $2"
Nach dem Login kopieren

zcard,exists操作

select count(*) as num from rstore_zset where "rkey" = $1
Nach dem Login kopieren

zcount操作

select count(*) as num from rstore_zset where "rkey" = $1 and score>=$2 and score<=$3
Nach dem Login kopieren

zremrangebyscore操作

delete from rstore_zset where "rkey" = $1 and score>=$2 and score<=$3
Nach dem Login kopieren

zrangebyscore操作

select member,score from rstore_zset
where "rkey" = $1 and score>=$2 and score<=$3 order by score asc,member asc
Nach dem Login kopieren

zrange操作

select member,score from rstore_zset
where "rkey" = $1 order by score asc offset $2 limit $3
Nach dem Login kopieren

zrank操作

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;
Nach dem Login kopieren

ttl操作

select max(lastTIme) from rstore_zset  where  "rkey" = $1
Nach dem Login kopieren

del操作

delete from rstore_zset where "rkey" = $1
Nach dem Login kopieren

set设计

RedisSetstring类型的无序集合。

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

rkey        varchar
member        varchar
lastTime    bigint
Nach dem Login kopieren

sadd操作

insert into rstore_set("rkey","member","lastTime") values($1,$2,$3)
on duplicate key update update set "lastTime"=$3
Nach dem Login kopieren

scard操作

select count(*) as num from rstore_set where "rkey" = $1
Nach dem Login kopieren

sismember操作

select member from rstore_set where "rkey" = $1 and "member" = $2
Nach dem Login kopieren

smembers操作

select member from rstore_set where "rkey" = $1
Nach dem Login kopieren

srem操作

delete from rstore_set where "rkey" = $1 and "member" = $2
Nach dem Login kopieren

del操作

delete from rstore_set where "rkey" = $1
Nach dem Login kopieren

ttl操作

select max(lastTIme) from rstore_set  where  "rkey" = $1
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonSo simulieren Sie Redis mit MySQL. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1658
14
PHP-Tutorial
1257
29
C#-Tutorial
1231
24
MySQL und PhpMyAdmin: Kernfunktionen und Funktionen MySQL und PhpMyAdmin: Kernfunktionen und Funktionen Apr 22, 2025 am 12:12 AM

MySQL und PhpMyAdmin sind leistungsstarke Datenbankverwaltungs -Tools. 1) MySQL wird verwendet, um Datenbanken und Tabellen zu erstellen und DML- und SQL -Abfragen auszuführen. 2) PHPMYADMIN bietet eine intuitive Schnittstelle für Datenbankverwaltung, Tabellenstrukturverwaltung, Datenoperationen und Benutzerberechtigungsverwaltung.

Wie verwendet ich die Redis -Cache -Lösung, um die Anforderungen der Produktranking -Liste effizient zu erkennen? Wie verwendet ich die Redis -Cache -Lösung, um die Anforderungen der Produktranking -Liste effizient zu erkennen? Apr 19, 2025 pm 11:36 PM

Wie erkennt die Redis -Caching -Lösung die Anforderungen der Produktranking -Liste? Während des Entwicklungsprozesses müssen wir uns häufig mit den Anforderungen der Ranglisten befassen, z. B. das Anzeigen eines ...

Redis 'Rolle: Erforschung der Datenspeicher- und Verwaltungsfunktionen Redis 'Rolle: Erforschung der Datenspeicher- und Verwaltungsfunktionen Apr 22, 2025 am 12:10 AM

Redis spielt eine Schlüsselrolle bei der Datenspeicherung und -verwaltung und ist durch seine mehreren Datenstrukturen und Persistenzmechanismen zum Kern moderner Anwendungen geworden. 1) Redis unterstützt Datenstrukturen wie Zeichenfolgen, Listen, Sammlungen, geordnete Sammlungen und Hash -Tabellen und eignet sich für Cache und komplexe Geschäftslogik. 2) RDB und AOF sorgt durch zwei Persistenzmethoden für eine zuverlässige Speicherung und eine schnelle Wiederherstellung von Daten.

Was tun, wenn der Redis -Cache im Spring -Boot fehlschlägt? Was tun, wenn der Redis -Cache im Spring -Boot fehlschlägt? Apr 19, 2025 pm 08:03 PM

Verwenden Sie im Springboot Redis, um das OAuth2Authorization -Objekt zu speichern. Verwenden Sie in der Springboot -Anwendung SpringSecurityoAuth2AuthorizationServer ...

Erklären Sie den Zweck von Fremdschlüssel in MySQL. Erklären Sie den Zweck von Fremdschlüssel in MySQL. Apr 25, 2025 am 12:17 AM

In MySQL besteht die Funktion von Fremdschlüssel darin, die Beziehung zwischen Tabellen herzustellen und die Konsistenz und Integrität der Daten zu gewährleisten. Fremdeschlüssel behalten die Wirksamkeit von Daten durch Referenzintegritätsprüfungen und Kaskadierungsvorgänge bei. Achten Sie auf die Leistungsoptimierung und vermeiden Sie bei der Verwendung häufige Fehler.

Wie kann ich JavaScript -Objekte, die Funktionen und reguläre Ausdrücke in einer Datenbank und wiederherstellen, sicher speichern? Wie kann ich JavaScript -Objekte, die Funktionen und reguläre Ausdrücke in einer Datenbank und wiederherstellen, sicher speichern? Apr 19, 2025 pm 11:09 PM

Mit sicheren Funktionen und regulären Ausdrücken in JSON in der Front-End-Entwicklung ist JavaScript häufig erforderlich ...

Wie kann in einer Multi-Knoten-Umgebung sichergestellt werden, dass die @Scheduled-Timing-Aufgabe von Spring Boot nur auf einem Knoten ausgeführt wird? Wie kann in einer Multi-Knoten-Umgebung sichergestellt werden, dass die @Scheduled-Timing-Aufgabe von Spring Boot nur auf einem Knoten ausgeführt wird? Apr 19, 2025 pm 10:57 PM

Die Optimierungslösung für Springboot-Timing-Aufgaben in einer Multi-Knoten-Umgebung ist die Entwicklung des Frühlings ...

Vergleichen und kontrastieren Sie MySQL und Mariadb. Vergleichen und kontrastieren Sie MySQL und Mariadb. Apr 26, 2025 am 12:08 AM

Der Hauptunterschied zwischen MySQL und Mariadb ist Leistung, Funktionalität und Lizenz: 1. MySQL wird von Oracle entwickelt und Mariadb ist seine Gabel. 2. Mariadb kann in Umgebungen mit hoher Last besser abschneiden. 3.MariADB bietet mehr Speichermotoren und Funktionen. 4.Mysql nimmt eine doppelte Lizenz an, und Mariadb ist vollständig Open Source. Die vorhandene Infrastruktur, Leistungsanforderungen, funktionale Anforderungen und Lizenzkosten sollten bei der Auswahl berücksichtigt werden.

See all articles