Heim Backend-Entwicklung C#.Net-Tutorial Redis-Tutorial (7): Detaillierte Erläuterung der Tastenbedienungsbefehle

Redis-Tutorial (7): Detaillierte Erläuterung der Tastenbedienungsbefehle

Dec 28, 2016 pm 02:55 PM
key redis

1. Übersicht:

In den ersten Blogs dieser Serie haben wir hauptsächlich über Befehle gesprochen, die sich auf Redis-Datentypen beziehen, wie z. B. String, List, Set, Hashes und Sorted-Set. Diese Befehle haben alle eines gemeinsam: Alle Operationen werden für den mit dem Schlüssel verknüpften Wert ausgeführt. Dieser Blog konzentriert sich auf schlüsselbezogene Redis-Befehle. Das Erlernen dieser Befehle ist eine sehr wichtige Grundlage für das Erlernen von Redis und ein leistungsstarkes Werkzeug, um das Potenzial von Redis voll auszuschöpfen.
In diesem Blog werden wir wie immer eine detaillierte Liste und typische Beispiele aller zugehörigen Befehle bereitstellen, um unser aktuelles Lernen und zukünftige Referenzen zu erleichtern.

2. Zugehörige Befehlsliste:


Befehlsprototyp Zeitkomplexität Befehlsbeschreibung Rückgabewert
KEYS-Muster O(N) Das N in der Zeitkomplexität stellt die Anzahl der Schlüssel in der Datenbank dar. Ruft alle Schlüssel ab, die dem Musterparameter entsprechen. Es ist zu beachten, dass wir versuchen sollten, den Aufruf dieses Befehls in unserem normalen Betrieb zu vermeiden, da dieser Befehl bei großen Datenbanken sehr zeitaufwändig ist und einen relativ großen Einfluss auf die Leistung des Redis-Servers hat. Das Muster unterstützt das Platzhalterformat im Glob-Stil, z. B. * für ein oder mehrere Zeichen, ? für ein beliebiges Zeichen, [abc] für einen beliebigen Buchstaben in eckigen Klammern Schlüsselliste, die dem Muster entspricht.
DEL-Taste [Taste ...] O(N) Das N in der Zeitkomplexität stellt die Anzahl der gelöschten Schlüssel dar. Löschen Sie die in den Parametern angegebenen Schlüssel aus der Datenbank. Wenn der angegebene Schlüssel nicht vorhanden ist, wird er ignoriert. Es sollte auch darauf hingewiesen werden, dass die Zeitkomplexität dieses Befehls zum Löschen jedes Schlüssels O beträgt, wenn der mit dem angegebenen Schlüssel verknüpfte Datentyp kein String-Typ, sondern ein Containertyp wie Liste, Set, Hashes und Sorted Set ist (M), wobei M die Anzahl der Elemente im Container darstellt. Für den String-Typ Key beträgt seine zeitliche Komplexität O(1). Die tatsächliche Anzahl der gelöschten Schlüssel.
EXISTS-Schlüssel O(1) Bestimmen Sie, ob der angegebene Schlüssel vorhanden ist. 1 bedeutet Existenz, 0 bedeutet nicht existieren.
MOVE key db O(1) Verschieben Sie den in der aktuellen Datenbank angegebenen Schlüssel Key in die im Parameter angegebene Datenbank. Wenn der Schlüssel bereits in der Zieldatenbank vorhanden ist oder in der aktuellen Datenbank nicht vorhanden ist, führt dieser Befehl nichts aus und gibt 0 zurück. Gibt 1 zurück, wenn die Verschiebung erfolgreich ist, andernfalls 0.
Schlüssel neu benennen O(1) Den angegebenen Schlüssel umbenennen, wenn die Befehle der beiden Schlüssel in den Parametern gleich sind. Oder der Quellschlüssel ist nicht vorhanden. Dieser Befehl gibt relevante Fehlerinformationen zurück. Wenn newKey bereits existiert, wird er direkt überschrieben.
RENAMENX-Schlüssel neuer Schlüssel O(1) Wenn der neue Wert nicht vorhanden ist, ändern Sie den ursprünglichen Wert im Parameter in den neuen Wert . Andere Bedingungen stimmen mit RENAME überein. 1 bedeutet, dass die Änderung erfolgreich war, andernfalls 0.
PERSIST-Schlüssel O(1) Wenn der Schlüssel eine Ablaufzeit hat, eliminiert dieser Befehl seine Ablaufzeit, sodass der Schlüssel dies tut Es gibt keine Zeitüberschreitungen mehr, eine dauerhafte Speicherung ist jedoch möglich. 1 bedeutet, dass die Ablaufzeit des Schlüssels entfernt wurde, 0 bedeutet, dass der Schlüssel nicht existiert oder keine Ablaufzeit hat
EXPIRE-Schlüsselsekunden O(1) Dieser Befehl legt die Timeout-Sekunden für den im Parameter angegebenen Schlüssel fest. Nach Überschreiten dieser Zeit wird der Schlüssel automatisch gelöscht. Wenn der Schlüssel geändert wird, bevor das Zeitlimit eintritt, wird das mit dem Schlüssel verbundene Zeitlimit entfernt. 1 bedeutet, dass das Timeout gesetzt ist, 0 bedeutet, dass der Schlüssel nicht existiert oder nicht gesetzt werden kann.
EXPIREAT-Schlüsselzeitstempel O(1) Die logische Funktion dieses Befehls ist genau die gleiche wie EXPIRE, der einzige Unterschied ist die Zeitüberschreitung Die durch diesen Befehl angegebene Zeit ist absolute Zeit, nicht relative Zeit. Der Zeitparameter liegt im Unix-Zeitstempelformat vor und gibt die Anzahl der Sekunden an, die seit dem 1. Januar 1970 vergangen sind. 1 bedeutet, dass das Timeout gesetzt ist, 0 bedeutet, dass der Schlüssel nicht existiert oder nicht gesetzt werden kann.
TTL-Taste O(1) Rufen Sie die verbleibende Timeout-Beschreibung der Taste ab. Gibt die verbleibende Beschreibung zurück oder -1, wenn der Schlüssel nicht existiert oder kein Timeout festgelegt ist.
RANDOMKEY O(1) Gibt einen zufälligen Schlüssel aus der aktuell geöffneten Datenbank zurück. Der zurückgegebene Zufallsschlüssel oder Null, wenn die Datenbank leer ist.
TYPE-Schlüssel O(1) Ruft den Typ des Werts ab, der dem im Parameter angegebenen Schlüssel zugeordnet ist. Dieser Befehl gibt ihn zurück String-Format. Die zurückgegebenen Zeichenfolgen sind string, list, set, hash und zset. Wenn der Schlüssel nicht vorhanden ist, geben Sie keine zurück
SORT-Schlüssel [NACH Muster] [LIMIT-Offset count] [GET-Muster [GET-Muster ...]] [ASC|DESC] [ALPHA] [STORE-Ziel] O(N+M*log(M)) Dieser Befehl ist relativ Es soll relativ kompliziert sein, daher geben wir hier nur die grundlegendste Verwendung an. Interessierte Internetnutzer können sich auf die offizielle Dokumentation von Redis beziehen. Gibt die ursprünglich sortierte Liste zurück.

3. Befehlsbeispiele:

1. KEYS/RENAME/DEL/EXISTS/MOVE/RENAMENX:

    #在Shell命令行下启动Redis客户端工具。
    /> redis-cli
    #清空当前选择的数据库,以便于对后面示例的理解。
    redis 127.0.0.1:6379> flushdb
    OK
    #添加String类型的模拟数据。
    redis 127.0.0.1:6379> set mykey 2
    OK
    redis 127.0.0.1:6379> set mykey2 "hello"
    OK
    #添加Set类型的模拟数据。
    redis 127.0.0.1:6379> sadd mysetkey 1 2 3
    (integer) 3
    #添加Hash类型的模拟数据。
    redis 127.0.0.1:6379> hset mmtest username "stephen"
    (integer) 1
    #根据参数中的模式,获取当前数据库中符合该模式的所有key,从输出可以看出,该命令在执行时并不区分与Key关联的Value类型。
    redis 127.0.0.1:6379> keys my*
    1) "mysetkey"
    2) "mykey"
    3) "mykey2"
    #删除了两个Keys。
    redis 127.0.0.1:6379> del mykey mykey2
    (integer) 2
    #查看一下刚刚删除的Key是否还存在,从返回结果看,mykey确实已经删除了。
    redis 127.0.0.1:6379> exists mykey
    (integer) 0
    #查看一下没有删除的Key,以和上面的命令结果进行比较。
    redis 127.0.0.1:6379> exists mysetkey
    (integer) 1
    #将当前数据库中的mysetkey键移入到ID为1的数据库中,从结果可以看出已经移动成功。
    redis 127.0.0.1:6379> move mysetkey 1
    (integer) 1
    #打开ID为1的数据库。
    redis 127.0.0.1:6379> select 1
    OK
    #查看一下刚刚移动过来的Key是否存在,从返回结果看已经存在了。
    redis 127.0.0.1:6379[1]> exists mysetkey
    (integer) 1
    #在重新打开ID为0的缺省数据库。
    redis 127.0.0.1:6379[1]> select 0
    OK
    #查看一下刚刚移走的Key是否已经不存在,从返回结果看已经移走。
    redis 127.0.0.1:6379> exists mysetkey
    (integer) 0
    #准备新的测试数据。    
    redis 127.0.0.1:6379> set mykey "hello"
    OK
    #将mykey改名为mykey1
    redis 127.0.0.1:6379> rename mykey mykey1
    OK
    #由于mykey已经被重新命名,再次获取将返回nil。
    redis 127.0.0.1:6379> get mykey
    (nil)
    #通过新的键名获取。
    redis 127.0.0.1:6379> get mykey1
    "hello"
    #由于mykey已经不存在了,所以返回错误信息。
    redis 127.0.0.1:6379> rename mykey mykey1
    (error) ERR no such key
    #为renamenx准备测试key
    redis 127.0.0.1:6379> set oldkey "hello"
    OK
    redis 127.0.0.1:6379> set newkey "world"
    OK
    #由于newkey已经存在,因此该命令未能成功执行。
    redis 127.0.0.1:6379> renamenx oldkey newkey
    (integer) 0
    #查看newkey的值,发现它也没有被renamenx覆盖。
    redis 127.0.0.1:6379> get newkey
    "world"
Nach dem Login kopieren

2 . PERSIST/EXPIRE/EXPIREAT/TTL:

#为后面的示例准备的测试数据。
    redis 127.0.0.1:6379> set mykey "hello"
    OK
    #将该键的超时设置为100秒。
    redis 127.0.0.1:6379> expire mykey 100
    (integer) 1
    #通过ttl命令查看一下还剩下多少秒。
    redis 127.0.0.1:6379> ttl mykey
    (integer) 97
    #立刻执行persist命令,该存在超时的键变成持久化的键,即将该Key的超时去掉。
    redis 127.0.0.1:6379> persist mykey
    (integer) 1
    #ttl的返回值告诉我们,该键已经没有超时了。
    redis 127.0.0.1:6379> ttl mykey
    (integer) -1
    #为后面的expire命令准备数据。
    redis 127.0.0.1:6379> del mykey
    (integer) 1
    redis 127.0.0.1:6379> set mykey "hello"
    OK
    #设置该键的超时被100秒。
    redis 127.0.0.1:6379> expire mykey 100
    (integer) 1
    #用ttl命令看一下当前还剩下多少秒,从结果中可以看出还剩下96秒。
    redis 127.0.0.1:6379> ttl mykey
    (integer) 96
    #重新更新该键的超时时间为20秒,从返回值可以看出该命令执行成功。
    redis 127.0.0.1:6379> expire mykey 20
    (integer) 1
    #再用ttl确认一下,从结果中可以看出果然被更新了。
    redis 127.0.0.1:6379> ttl mykey
    (integer) 17
    #立刻更新该键的值,以使其超时无效。
    redis 127.0.0.1:6379> set mykey "world"
    OK
    #从ttl的结果可以看出,在上一条修改该键的命令执行后,该键的超时也无效了。
    redis 127.0.0.1:6379> ttl mykey
    (integer) -1
Nach dem Login kopieren

3. TYPE/RANDOMKEY/SORT:

#由于mm键在数据库中不存在,因此该命令返回none。
    redis 127.0.0.1:6379> type mm
    none
    #mykey的值是字符串类型,因此返回string。
    redis 127.0.0.1:6379> type mykey
    string
    #准备一个值是set类型的键。
    redis 127.0.0.1:6379> sadd mysetkey 1 2
    (integer) 2
    #mysetkey的键是set,因此返回字符串set。
    redis 127.0.0.1:6379> type mysetkey
    set
    #返回数据库中的任意键。
    redis 127.0.0.1:6379> randomkey
    "oldkey"
    #清空当前打开的数据库。
    redis 127.0.0.1:6379> flushdb
    OK
    #由于没有数据了,因此返回nil。
    redis 127.0.0.1:6379> randomkey
    (nil)
Nach dem Login kopieren

Das Obige ist das Redis-Tutorial (7): Ausführliche Erklärung Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!


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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

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)

So erstellen Sie den Redis -Clustermodus So erstellen Sie den Redis -Clustermodus Apr 10, 2025 pm 10:15 PM

Der Redis -Cluster -Modus bietet Redis -Instanzen durch Sharding, die Skalierbarkeit und Verfügbarkeit verbessert. Die Bauschritte sind wie folgt: Erstellen Sie ungerade Redis -Instanzen mit verschiedenen Ports; Erstellen Sie 3 Sentinel -Instanzen, Monitor -Redis -Instanzen und Failover; Konfigurieren von Sentinel -Konfigurationsdateien, Informationen zur Überwachung von Redis -Instanzinformationen und Failover -Einstellungen hinzufügen. Konfigurieren von Redis -Instanzkonfigurationsdateien, aktivieren Sie den Cluster -Modus und geben Sie den Cluster -Informationsdateipfad an. Erstellen Sie die Datei nodes.conf, die Informationen zu jeder Redis -Instanz enthält. Starten Sie den Cluster, führen Sie den Befehl erstellen aus, um einen Cluster zu erstellen und die Anzahl der Replikate anzugeben. Melden Sie sich im Cluster an, um den Befehl cluster info auszuführen, um den Clusterstatus zu überprüfen. machen

So verwenden Sie den Befehl Redis So verwenden Sie den Befehl Redis Apr 10, 2025 pm 08:45 PM

Die Verwendung der REDIS -Anweisung erfordert die folgenden Schritte: Öffnen Sie den Redis -Client. Geben Sie den Befehl ein (Verbschlüsselwert). Bietet die erforderlichen Parameter (variiert von der Anweisung bis zur Anweisung). Drücken Sie die Eingabetaste, um den Befehl auszuführen. Redis gibt eine Antwort zurück, die das Ergebnis der Operation anzeigt (normalerweise in Ordnung oder -err).

So sehen Sie alle Schlüssel in Redis So sehen Sie alle Schlüssel in Redis Apr 10, 2025 pm 07:15 PM

Um alle Schlüssel in Redis anzuzeigen, gibt es drei Möglichkeiten: Verwenden Sie den Befehl keys, um alle Schlüssel zurückzugeben, die dem angegebenen Muster übereinstimmen. Verwenden Sie den Befehl scan, um über die Schlüssel zu iterieren und eine Reihe von Schlüssel zurückzugeben. Verwenden Sie den Befehl Info, um die Gesamtzahl der Schlüssel zu erhalten.

So starten Sie den Server mit Redis So starten Sie den Server mit Redis Apr 10, 2025 pm 08:12 PM

Zu den Schritten zum Starten eines Redis -Servers gehören: Installieren von Redis gemäß dem Betriebssystem. Starten Sie den Redis-Dienst über Redis-Server (Linux/macOS) oder redis-server.exe (Windows). Verwenden Sie den Befehl redis-cli ping (linux/macOS) oder redis-cli.exe ping (Windows), um den Dienststatus zu überprüfen. Verwenden Sie einen Redis-Client wie Redis-Cli, Python oder Node.js, um auf den Server zuzugreifen.

So implementieren Sie die zugrunde liegenden Redis So implementieren Sie die zugrunde liegenden Redis Apr 10, 2025 pm 07:21 PM

Redis verwendet Hash -Tabellen, um Daten zu speichern und unterstützt Datenstrukturen wie Zeichenfolgen, Listen, Hash -Tabellen, Sammlungen und geordnete Sammlungen. Ernähren sich weiterhin über Daten über Snapshots (RDB) und appendiert Mechanismen nur Schreibmechanismen. Redis verwendet die Master-Slave-Replikation, um die Datenverfügbarkeit zu verbessern. Redis verwendet eine Ereignisschleife mit einer Thread, um Verbindungen und Befehle zu verarbeiten, um die Datenatomizität und Konsistenz zu gewährleisten. Redis legt die Ablaufzeit für den Schlüssel fest und verwendet den faulen Löschmechanismus, um den Ablaufschlüssel zu löschen.

So lesen Sie den Quellcode von Redis So lesen Sie den Quellcode von Redis Apr 10, 2025 pm 08:27 PM

Der beste Weg, um Redis -Quellcode zu verstehen, besteht darin, Schritt für Schritt zu gehen: Machen Sie sich mit den Grundlagen von Redis vertraut. Wählen Sie ein bestimmtes Modul oder eine bestimmte Funktion als Ausgangspunkt. Beginnen Sie mit dem Einstiegspunkt des Moduls oder der Funktion und sehen Sie sich die Codezeile nach Zeile an. Zeigen Sie den Code über die Funktionsaufrufkette an. Kennen Sie die von Redis verwendeten Datenstrukturen. Identifizieren Sie den von Redis verwendeten Algorithmus.

So verwenden Sie Redis Lock So verwenden Sie Redis Lock Apr 10, 2025 pm 08:39 PM

Um die Operationen zu sperren, muss die Sperre durch den Befehl setNX erfasst werden und dann den Befehl Ablauf verwenden, um die Ablaufzeit festzulegen. Die spezifischen Schritte sind: (1) Verwenden Sie den Befehl setNX, um zu versuchen, ein Schlüsselwertpaar festzulegen; (2) Verwenden Sie den Befehl Ablauf, um die Ablaufzeit für die Sperre festzulegen. (3) Verwenden Sie den Befehl Del, um die Sperre zu löschen, wenn die Sperre nicht mehr benötigt wird.

So löschen Sie Redis -Daten So löschen Sie Redis -Daten Apr 10, 2025 pm 10:06 PM

So löschen Sie Redis -Daten: Verwenden Sie den Befehl Flushall, um alle Schlüsselwerte zu löschen. Verwenden Sie den Befehl flushdb, um den Schlüsselwert der aktuell ausgewählten Datenbank zu löschen. Verwenden Sie SELECT, um Datenbanken zu wechseln, und löschen Sie dann FlushDB, um mehrere Datenbanken zu löschen. Verwenden Sie den Befehl del, um einen bestimmten Schlüssel zu löschen. Verwenden Sie das Redis-Cli-Tool, um die Daten zu löschen.

See all articles