Vielleicht haben Sie schon vorher Modelldaten zwischengespeichert, aber ich zeige Ihnen eine ausgefeiltere Laravel-Modell-Caching-Technik mit dynamisch protokollierten Modellen, die ich mit den von RailsCasts erlernten Techniken begonnen habe.
Mithilfe des eindeutigen Cache-Schlüssels des Modells können Sie Eigenschaften und Zuordnungen im Modell zwischenspeichern, die automatisch aktualisiert (und im Cache ungültig gemacht) werden, wenn das Modell (oder das zugehörige Modell) aktualisiert wird. Ein Vorteil besteht darin, dass der Zugriff auf zwischengespeicherte Daten schneller ist als im Controller. Die zwischengespeicherten Daten sind besser wiederverwendbar, da sie sich im Modell befinden und nicht in einer einzelnen Controller-Methode.
Dies ist der Kernpunkt dieser Technologie:
Angenommen, Sie haben viele Kommentar-Artikel-Modelle. Wenn Sie die folgende Laravel-Blade-Vorlage verwenden, können Sie wie folgt auf die Route /article/:id zugreifen Holen Sie sich die Anzahl der Kommentare:
<h3 id="article-comments-count-nbsp-nbsp-str-plural-Comment-nbsp-article-comments-count">$article->comments->count() {{ str_plural('Comment', $article->comments->count())</h3>
Sie können die Anzahl der Kommentare im Controller zwischenspeichern, aber wenn Sie mehrere einmalige Abfragen und Daten haben, die zwischengespeichert werden müssen, kann der Controller sehr aufgebläht und hässlich werden. Auch der Zugriff auf zwischengespeicherte Daten ist bei Verwendung von Controllern nicht sehr komfortabel.
Wir können eine Vorlage erstellen, die nur dann auf die Datenbank zugreift, wenn der Artikel aktualisiert wird, und der gesamte Code, der auf das Modell zugreift, kann den zwischengespeicherten Wert erhalten:
<h3 id="article-cached-comments-count-nbsp-nbsp-str-plural-Comment-nbsp-article-cached-comments-count">$article->cached_comments_count {{ str_plural('Comment', $article->cached_comments_count)</h3>
Durch die Verwendung des Modellzugriffs können wir dies tun Cache-Kommentaranzahl basierend auf der letzten Artikelaktualisierung.
Wie sollten wir also den Wert der Spalte „update_at“ des Artikels aktualisieren, wenn ein Kommentar hinzugefügt oder gelöscht wird?
Geben Sie zunächst die Touch-Methode ein, um einen Blick darauf zu werfen.
Auslösung des Modells
Sie können den Spaltenwert „update_at“ des Artikels aktualisieren, indem Sie die touch()-Methode des Modells verwenden:
$ php artisan tinker
>>> $article = \App\Article::first(); => App\Article {#746 id: 1, title: "Hello World", body: "The Body", created_at: "2018-01-11 05:16:51", updated_at: "2018-01-11 05:51:07", } >>> $article->updated_at->timestamp => 1515649867 >>> $article->touch(); => true >>> $article->updated_at->timestamp => 1515650910
Wir können den Cache mit einem aktualisierten Zeitstempelwert ungültig machen. Aber wie lösen wir beim Hinzufügen oder Löschen eines Kommentars die Änderung des Feldes „update_at“ des Artikels aus?
Es kommt vor, dass es im Eloquent-Modell eine Eigenschaft namens $touches gibt. So sieht unser Kommentarmodell aus:
<?php namespace App; use App\Article; use Illuminate\Database\Eloquent\Model; class Comment extends Model { protected $guarded = []; protected $touches = ['article']; public function article() { return $this->belongsTo(Article::class); } }
Die $touches-Eigenschaft hier ist ein Array, das die zugehörigen Informationen enthält, die „Trigger“ auslösen, wenn der Kommentar erstellt, gespeichert und gelöscht wird.
Gespeicherte Eigenschaften
Kehren wir zum $article->cached_comments_count-Accessor zurück. Die Implementierung dieser Methode könnte im AppArticle-Modell wie folgt aussehen:
public function getCachedCommentsCountAttribute() { return Cache::remember($this->cacheKey() . ':comments_count', 15, function () { return $this->comments->count(); }); }
Wir zwischenspeichern das Modell 15 Minuten lang mit der Methode „cacheKey()“ des eindeutigen Schlüssels und geben dann einfach die Überprüfungsanzahl in der Abschlussmethode zurück .
Beachten Sie, dass wir auch die Methode Cache::rememberForever() verwenden und dabei auf die Garbage-Collection-Strategie des Cache-Mechanismus zurückgreifen, um abgelaufene Schlüsselwerte zu löschen. Ich habe einen Timer eingerichtet, damit der Cache während des Cache-Aktualisierungsintervalls alle 15 Minuten die meiste Zeit die höchste Trefferquote aufweist.
Die Methode „cacheKey()“ verwendet den eindeutigen Schlüsselwert des Modells und der Cache wird ungültig, wenn das Modell aktualisiert wird. Das Folgende ist mein CacheKey-Implementierungscode:
public function cacheKey() { return sprintf( "%s/%s-%s", $this->getTable(), $this->getKey(), $this->updated_at->timestamp ); }
Das Beispiel der CacheKey()-Methode des Modells kann die folgenden Zeichenfolgeninformationen zurückgeben:
articles/1-1515650910
Dieser Schlüsselwert besteht aus dem Tabellennamen und der Modell-ID value und der Zeitstempelwert des aktuellen aktualisierten_at. Sobald wir dieses Modell auslösen, wird der Zeitstempelwert aktualisiert und unser Modellcache wird entsprechend ungültig.
Hier ist der vollständige Code für das Artikelmodell:
<?php namespace App; use App\Comment; use Illuminate\Support\Facades\Cache; use Illuminate\Database\Eloquent\Model; class Article extends Model { public function cacheKey() { return sprintf( "%s/%s-%s", $this->getTable(), $this->getKey(), $this->updated_at->timestamp ); } public function comments() { return $this->hasMany(Comment::class); } public function getCachedCommentsCountAttribute() { return Cache::remember($this->cacheKey() . ':comments_count', 15, function () { return $this->comments->count(); }); } }
Und dann das zugehörige Kommentarmodell:
<?php namespace App; use App\Article; use Illuminate\Database\Eloquent\Model; class Comment extends Model { protected $guarded = []; protected $touches = ['article']; public function article() { return $this->belongsTo(Article::class); } }
Was kommt als Nächstes?
Ich habe Ihnen gezeigt, wie Sie eine einfache Kommentarzählung zwischenspeichern, aber wie sieht es mit dem Zwischenspeichern aller Kommentare aus?
public function getCachedCommentsAttribute() { return Cache::remember($this->cacheKey() . ':comments', 15, function () { return $this->comments; }); }
Sie können die Kommentare auch in ein Array konvertieren, anstatt das Modell zu serialisieren, sodass nur ein einfacher Array-Zugriff auf die Daten im Frontend möglich ist:
public function getCachedCommentsAttribute() { return Cache::remember($this->cacheKey() . ':comments', 15, function () { return $this->comments->toArray(); }); }
Schließlich habe ich den Cache-Schlüssel definiert die Article model()-Methode, aber Sie möchten diese Methode möglicherweise über eine Eigenschaft namens ProvidesModelCacheKey definieren, damit Sie sie in einem zusammengesetzten Modell verwenden oder die Methode für alle Modellerweiterungen in einem Basismodell definieren können. Möglicherweise möchten Sie sogar einen Vertrag (Schnittstelle) für Ihr Modell verwenden, der die Methode „cacheKey()“ implementiert.
Empfohlene Tutorials: „PHP-Tutorial“ „Laravel“
Das obige ist der detaillierte Inhalt vonWie werden Daten auf der Modellebene in Laravel zwischengespeichert?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Das Laravel -Entwicklungsprojekt wurde aufgrund seiner Flexibilität und Kraft ausgewählt, um den Bedürfnissen unterschiedlicher Größen und Komplexität zu entsprechen. Laravel bietet Routing-System, eloquentorm, Artisan Command Line und andere Funktionen und unterstützt die Entwicklung von einfachen Blogs bis hin zu komplexen Systemen auf Unternehmensebene.

Der Vergleich zwischen Laravel und Python in der Entwicklungsumgebung und dem Ökosystem ist wie folgt: 1. Die Entwicklungsumgebung von Laravel ist einfach, nur PHP und Komponist sind erforderlich. Es bietet eine umfassende Auswahl an Erweiterungspaketen wie Laravelforge, aber die Wartung des Erweiterungspakets ist möglicherweise nicht rechtzeitig. 2. Die Entwicklungsumgebung von Python ist ebenfalls einfach, nur Python und PIP sind erforderlich. Das Ökosystem ist riesig und deckt mehrere Felder ab, aber das Versions- und Abhängigkeitsmanagement kann komplex sein.

Wie spielt Laravel eine Rolle in der Backend -Logik? Es vereinfacht und verbessert die Backend -Entwicklung durch Routing -Systeme, eloquentorm, Authentifizierung und Autorisierung, Ereignis und Zuhörer sowie Leistungsoptimierung. 1. Das Routing -System ermöglicht die Definition der URL -Struktur und die Anforderungsverarbeitungslogik. 2.Loquentorm vereinfacht die Datenbankinteraktion. 3. Das Authentifizierungs- und Autorisierungssystem ist für die Benutzerverwaltung geeignet. 4. Die Ereignis und der Hörer implementieren locker gekoppelte Codestruktur. 5. Leistungsoptimierung verbessert die Anwendungseffizienz durch Zwischenspeicherung und Warteschlange.

Die Popularität von Laravel umfasst seinen vereinfachten Entwicklungsprozess, eine angenehme Entwicklungsumgebung und umfangreiche Merkmale. 1) Es absorbiert die Designphilosophie von RubyonRails und kombiniert die Flexibilität von PHP. 2) Bereitstellung von Werkzeugen wie eloquentorm, Blade Template Engine usw. zur Verbesserung der Entwicklungseffizienz. 3) Sein MVC -Architektur- und Abhängigkeitsinjektionsmechanismus macht den Code modularer und prüfbarer. 4) Bietet leistungsstarke Debugging -Tools und Leistungsoptimierungsmethoden wie Caching -Systeme und Best Practices.

Sowohl Django als auch Laravel sind Full-Stack-Frameworks. Django eignet sich für Python -Entwickler und komplexe Geschäftslogik, während Laravel für PHP -Entwickler und elegante Syntax geeignet ist. 1.Django basiert auf Python und folgt der "batteriebetriebenen" Philosophie, die für schnelle Entwicklung und hohe Parallelität geeignet ist. 2. Laravel basiert auf PHP, der die Entwicklererfahrung betont und für kleine bis mittlere Projekte geeignet ist.

PHP und Laravel sind nicht direkt vergleichbar, da Laravel ein PHP-basierter Framework ist. 1.PHP ist für kleine Projekte oder schnelle Prototypen geeignet, da es einfach und direkt ist. 2. Laravel ist für große Projekte oder effiziente Entwicklung geeignet, da es umfangreiche Funktionen und Werkzeuge bietet, aber eine steile Lernkurve aufweist und möglicherweise nicht so gut ist wie reines PHP.

LaravelisabackendFrameworkBuiltonPhp, entworfene WebApplicationDevelopment.itfocuseSonserver-Sidelogic, DatabaSemanagement und Applicationsstruktur und CanBeintegratedWithFrontendTechnologies-ähnlich.

In dem Artikel wird das Erstellen und Verwenden benutzerdefinierter Blade -Richtlinien in Laravel erläutert, um die Vorlagen zu verbessern. Es umfasst die Definition von Direktiven, die Verwendung in Vorlagen und die Verwaltung in großen Projekten, um Vorteile wie eine verbesserte Wiederverwendbarkeit von Code und R hervorzuheben


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

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 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor