suchen
HeimDatenbankRedisSo führen Sie Paging in Redis durch

So führen Sie Paging in Redis durch

Die Benutzerkommentare unter jedem Thema werden zusammengestellt und in Redis geschrieben. Jedes Thema hat eine Themen-ID, und jeder Kommentar wird mit der Themen-ID verknüpft, grobe Daten Das Modell ist wie folgt: (Empfohlenes Lernen: Redis-Video-Tutorial)

{ topicId: 'xxxxxxxx', comments: [ { username: 'niuniu', createDate: 1447747334791, content: '在Redis中分页', commentId: 'xxxxxxx', reply: [ { content: 'yyyyyy' username: 'niuniu' }, ... ] }, ... ]}

Nachdem Sie die Kommentardaten von MySQL abgefragt, assembliert und in Redis gespeichert haben, können Sie die Assembly von Redis abrufen Jedes Mal, wenn gute Kommentardaten vorliegen, handelt es sich, wie aus dem obigen Datenmodell hervorgeht, ausschließlich um Schlüsselwertdaten, die mithilfe eines Hash gespeichert werden müssen. Allerdings müssen die Kommentardaten jedes Mal ausgelagert und sortiert werden durch das Feld „createDate“ muss der Hash sein. Paging und Sortierung sind nicht möglich.

Schauen wir uns also nacheinander die von Redis unterstützten Datentypen an:

1. Wird hauptsächlich zum Speichern von Zeichenfolgen verwendet und unterstützt offensichtlich kein Paging und Sortieren.

2. Hash: Wird hauptsächlich zum Speichern von Schlüsselwertdaten verwendet. Das Kommentarmodell besteht ausschließlich aus Schlüsselwertdaten, daher wird hier zweifellos Hash verwendet.

3. Wird hauptsächlich zum Speichern einer Liste verwendet. Jedes Element in der Liste wird in der Reihenfolge gespeichert, in der die Elemente eingefügt werden, und fügt sie dann in die Liste ein. Es scheint, dass Sortierung und Paginierung auch mit dem Start-Stopp-Befehl der LRANGE-Taste in List möglich sind.

Nun, hier scheint die Liste unsere Paging- und Sortieranforderungen zu erfüllen, aber Kommentare werden trotzdem gelöscht, sodass die Daten in Redis jedes Mal aktualisiert werden müssen, wenn ein Kommentar gelöscht wird Das einmalige Umschreiben aller Daten in Redis ist offensichtlich nicht elegant genug und die Effizienz wird erheblich beeinträchtigt. Es ist zweifellos besser, wenn die angegebenen Daten gelöscht werden können und RPOP, aber LPOP und RPOP Nur die Daten am Anfang und Ende der Liste können gelöscht werden, und die Daten an der angegebenen Position können nicht gelöscht werden (Hinweis: Es gibt tatsächlich einen LREM-Befehl, der gelöscht werden kann, aber das ist der Fall (sehr unpraktisch). Darüber hinaus kann diese Liste bei hohem gleichzeitigem Zugriff auf die Schnittstelle unbegrenzt erweitert werden und es werden viele Daten darin dupliziert, was sich auf das normale Geschäft auswirkt, sodass die Liste nicht geeignet ist.

4. Set: speichert hauptsächlich ungeordnete Sets, ungeordnet! ausschließen.

5. SortedSet: Speichert hauptsächlich geordnete Mengen. ZADD-Schlüsselbewertungsmitglied [[score, member]…] bindet eine Wertbewertung für die Sortierung an jedes hinzugefügte Elementmitglied nach der Größe des Score-Wertes Hier können Sie createDate als Score zum Sortieren verwenden.

Der Befehl ZREVRANGE key start stop in SortedSet kann die Mitglieder im angegebenen Bereich zurückgeben, die zum Paging verwendet werden können. Der Befehl ZREM key member in SortedSet kann das angegebene Mitglied entsprechend dem Schlüssel entfernen. was die Löschanforderungen erfüllen kann, ist SortedSet hier am besten geeignet (Zeitkomplexität O(log(N))).

Die Datentypen, die verwendet werden müssen, sind SortSet und Hash. SortSet wird für die Paging-Sortierung verwendet, und Hash wird zum Speichern spezifischer Schlüssel-Wert-Paardaten verwendet. In der SortSet-Struktur wird die Topic-ID jedes Themas als Schlüssel des Satzes verwendet, und das Erstellungsdatum und die Kommentar-ID der mit dem Thema verknüpften Kommentare werden als Bewertung bzw. Mitglied des Satzes verwendet. Die Reihenfolge der Kommentar-ID wird festgelegt entsprechend der Größe des createDate.

Wenn Sie die Kommentare auf einer bestimmten Seite eines bestimmten Themas abfragen müssen, können Sie die Themen-Topic-ID des Themas über den Befehl zrevrange topicId (Seite-1)×10 (Seite-1)×10 verwenden +perPage, damit Sie die Kommentare zu einem bestimmten Thema herausfinden können. Die CommitId aller Kommentare in chronologischer Reihenfolge auf einer Seite unter einem Thema. page ist die Seitennummer der Abfrageseite und perPage ist die Anzahl der auf jeder Seite angezeigten Elemente.

Nachdem Sie die Kommentar-ID aller Kommentare gefunden haben, können Sie diese Kommentar-IDs als Schlüssel verwenden, um den dem Kommentar entsprechenden Inhalt in der Hash-Struktur abzufragen.

Auf diese Weise werden die beiden Strukturen SortSet und Hash verwendet, um den Zweck des Pagings und Sortierens in Redis zu erreichen.

Natürlich können Sie statt des Hash-Typs auch einfach den Typ SrotedSet verwenden und die Kommentare direkt im Member speichern.

Aber warum Kommentare ablegen und in verschiedene Typen sortieren? Der Vorteil besteht darin, dass Sie verschiedene Sortierarten für Kommentare festlegen können, z. B. positive und negative Sortierung nach Zeit, positive und negative Sortierung nach Likes, positive und negative Sortierung nach Anzahl der Aufrufe usw. Auf diese Weise müssen Sie nur verschiedene SrotedSet-Sortierungen verwalten und müssen nicht den Inhalt mehrerer Kommentarsätze verwalten.

Das obige ist der detaillierte Inhalt vonSo führen Sie Paging in Redis durch. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
Redis: Erforschen des Datenmodells und der StrukturRedis: Erforschen des Datenmodells und der StrukturApr 16, 2025 am 12:09 AM

Das Datenmodell und die Struktur von Redis umfassen fünf Haupttypen: 1. String: Verwendet, um Text oder binäre Daten zu speichern, und unterstützt Atomoperationen. 2. Liste: Bestellte Elementssammlung, geeignet für Warteschlangen und Stapel. 3. SET: Ungeordnete einzigartige Elemente, unterstützende Set -Operation. V. 5. Hash Table (Hash): Eine Sammlung von Schlüsselwertpaaren, die zum Speichern von Objekten geeignet sind.

Redis: Klassifizierung des DatenbankansatzesRedis: Klassifizierung des DatenbankansatzesApr 15, 2025 am 12:06 AM

Die Datenbankmethoden von Redis umfassen In-Memory-Datenbanken und Schlüsselwertspeicher. 1) Redis speichert Daten im Speicher und liest und schreibt schnell. 2) Es wird Schlüsselwertpaare verwendet, um Daten zu speichern, unterstützt komplexe Datenstrukturen wie Listen, Sammlungen, Hash-Tabellen und geordnete Sammlungen, die für Caches und NoSQL-Datenbanken geeignet sind.

Warum Redis verwenden? Vorteile und VorteileWarum Redis verwenden? Vorteile und VorteileApr 14, 2025 am 12:07 AM

Redis ist eine leistungsstarke Datenbanklösung, da sie eine schnelle Leistung, umfangreiche Datenstrukturen, hohe Verfügbarkeit und Skalierbarkeit, Persistenzfunktionen und eine breite Palette von Ökosystemunterstützung bietet. 1) Extrem schnelle Leistung: Die Daten von Redis werden im Speicher gespeichert und verfügt über extrem schnelle Lesen und Schreibgeschwindigkeiten, die für Anwendungen mit hoher Parallelität und niedriger Latenz geeignet sind. 2) Reiche Datenstruktur: Unterstützt mehrere Datentypen wie Listen, Sammlungen usw., die für eine Vielzahl von Szenarien geeignet sind. 3) hohe Verfügbarkeit und Skalierbarkeit: Unterstützt die Master-Slave-Replikation und den Clustermodus, um eine hohe Verfügbarkeit und horizontale Skalierbarkeit zu erzielen. 4) Persistenz und Datensicherheit: Die Datenpersistenz werden durch RDB und AOF erreicht, um die Integrität und Zuverlässigkeit der Daten zu gewährleisten. 5) Weites Ökosystem und Unterstützung der Gemeinschaft: mit einem riesigen Ökosystem und einer aktiven Gemeinschaft.

NoSQL verstehen: Schlüsselmerkmale von RedisNoSQL verstehen: Schlüsselmerkmale von RedisApr 13, 2025 am 12:17 AM

Zu den wichtigsten Merkmalen von Redis gehören Geschwindigkeit, Flexibilität und Reich Datenstrukturunterstützung. 1) Geschwindigkeit: Redis ist eine In-Memory-Datenbank, und Lese- und Schreibvorgänge sind fast augenblicklich und für Cache und Sitzungsverwaltung geeignet. 2) Flexibilität: Unterstützt mehrere Datenstrukturen wie Zeichenfolgen, Listen, Sammlungen usw., die für die komplexe Datenverarbeitung geeignet sind. 3) Unterstützung bei der Datenstruktur: Bietet Zeichenfolgen, Listen, Sammlungen, Hash -Tabellen usw., die für unterschiedliche Geschäftsanforderungen geeignet sind.

Redis: Identifizierung seiner primären FunktionRedis: Identifizierung seiner primären FunktionApr 12, 2025 am 12:01 AM

Die Kernfunktion von Redis ist ein Hochleistungs-In-Memory-Datenspeicher- und Verarbeitungssystem. 1) Hochgeschwindigkeitsdatenzugriff: Redis speichert Daten im Speicher und bietet Lese- und Schreibgeschwindigkeit auf Mikrosekunden. 2) Reiche Datenstruktur: Unterstützt Zeichenfolgen, Listen, Sammlungen usw. und passt an eine Vielzahl von Anwendungsszenarien. 3) Persistenz: Behalten Sie Daten an, um durch RDB und AOF zu diskutieren. 4) Abonnement veröffentlichen: Kann in Nachrichtenwarteschlangen oder Echtzeit-Kommunikationssystemen verwendet werden.

Redis: Ein Leitfaden für beliebte DatenstrukturenRedis: Ein Leitfaden für beliebte DatenstrukturenApr 11, 2025 am 12:04 AM

Redis unterstützt eine Vielzahl von Datenstrukturen, darunter: 1. String, geeignet zum Speichern von Einzelwertdaten; 2. Liste, geeignet für Warteschlangen und Stapel; 3.. SET, verwendet zum Speichern nicht duplikatischer Daten; V. 5. Hash -Tabelle, geeignet zum Speichern von Objekten oder strukturierten Daten.

So implementieren Sie Redis -ZählerSo implementieren Sie Redis -ZählerApr 10, 2025 pm 10:21 PM

Der Redis-Zähler ist ein Mechanismus, der die Speicherung von Redis-Schlüsselwertpaaren verwendet, um Zählvorgänge zu implementieren, einschließlich der folgenden Schritte: Erstellen von Zählerschlüssel, Erhöhung der Zählungen, Verringerung der Anzahl, Zurücksetzen der Zählungen und Erhalt von Zählungen. Die Vorteile von Redis -Zählern umfassen schnelle Geschwindigkeit, hohe Parallelität, Haltbarkeit und Einfachheit und Benutzerfreundlichkeit. Es kann in Szenarien wie Benutzerzugriffszählungen, Echtzeit-Metrikverfolgung, Spielergebnissen und Ranglisten sowie Auftragsverarbeitungszählung verwendet werden.

So verwenden Sie die Befehlszeile der RedisSo verwenden Sie die Befehlszeile der RedisApr 10, 2025 pm 10:18 PM

Verwenden Sie das Redis-Befehlszeilen-Tool (REDIS-CLI), um Redis in folgenden Schritten zu verwalten und zu betreiben: Stellen Sie die Adresse und den Port an, um die Adresse und den Port zu stellen. Senden Sie Befehle mit dem Befehlsnamen und den Parametern an den Server. Verwenden Sie den Befehl Hilfe, um Hilfeinformationen für einen bestimmten Befehl anzuzeigen. Verwenden Sie den Befehl zum Beenden, um das Befehlszeilenwerkzeug zu beenden.

See all articles

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 vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.