


Laravel-Entwicklung: Wie implementiert man polymorphe Assoziationen mit Laravel Eloquent?
Laravel-Entwicklung: Wie verwende ich Laravel Eloquent, um polymorphe Assoziationen zu implementieren?
Polymorphe Assoziation ist ein wichtiges Merkmal von Laravel Eloquent, das es einem Modell ermöglicht, Beziehungen zu mehreren verschiedenen Modellen aufzubauen. In praktischen Anwendungen ist die Verarbeitung verschiedener Datentypen relativ einfach und effizient, insbesondere im Datenbankdesign. In diesem Artikel besprechen wir, wie man polymorphe Assoziationen mit Laravel Eloquent implementiert.
1. Was ist polymorphe Assoziation?
Polymorphe Assoziation bezieht sich auf die Herstellung einer Assoziationsbeziehung zwischen einem Modell und mehreren verschiedenen Modellen, die als Verweis auf eine allgemeine Kategorie angesehen werden kann. Es kann viele Anwendungen komfortabler machen, wie zum Beispiel:
- Bild-, Audio- und Videomodelle können alle polymorphe Assoziationen mit Kommentarmodellen herstellen, sodass Kommentare auf mehrere Datentypen angewendet werden können.
- Benutzer können polymorphe Assoziationen mit Kommentarmodellen herstellen und auf mehrere Datentypen wie Artikel, Bilder, Videos usw. anwenden.
- Das Bestellmodell kann eine polymorphe Verbindung mit dem Lieferadressmodell herstellen, sodass Bestellungen an mehrere Adresstypen geliefert werden können, z. B. Privathäuser, Unternehmen, Filialen usw.
2. Methoden zur Implementierung polymorpher Assoziationen
Werfen wir einen Blick darauf, wie man Laravel Eloquent zur Implementierung polymorpher Assoziationen verwendet.
Zunächst müssen wir das Design der Datentabelle berücksichtigen. Wir müssen eine Zwischentabelle erstellen, um polymorphe Beziehungen zwischen Modellen zu speichern. Diese Tabelle sollte die folgenden Spalten enthalten:
- id: Tabellen-Primärschlüssel-ID;
- target_id: Zielmodell-ID;
- source_id: Quelle ID des Modells.
- Das Folgende ist ein Beispiel für eine Datenbankmigrationsdatei:
<?php use IlluminateDatabaseMigrationsMigration; use IlluminateDatabaseSchemaBlueprint; use IlluminateSupportFacadesSchema; class CreateCommentsTable extends Migration { /** * Run the migrations. * * @return void */ public function up() { Schema::create('comments', function (Blueprint $table) { $table->id(); $table->morphs('commentable'); $table->text('content'); $table->timestamps(); }); Schema::create('votes', function (Blueprint $table) { $table->id(); $table->unsignedBigInteger('user_id'); $table->unsignedBigInteger('voteable_id'); $table->string('voteable_type'); $table->enum('type', ['up', 'down']); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('comments'); Schema::dropIfExists('votes'); } }
Nach dem Login kopierenIn der obigen Migrationsdatei haben wir zwei neue Tabellen erstellt: Kommentare und Stimmen.
Die Kommentartabelle enthält grundlegende Informationen des Kommentarmodells, und die Methode morphs() wird zum Implementieren des polymorphen Assoziationszeigens verwendet. Die Abstimmungstabelle ist ähnlich und verwendet die Felder voteable_id und voteable_type, um eine polymorphe Assoziation zu implementieren.
Als nächstes müssen wir die Assoziationsbeziehung im Eloquent-Modell definieren.
Kommentarmodell:
<?php namespace AppModels; use IlluminateDatabaseEloquentFactoriesHasFactory; use IlluminateDatabaseEloquentModel; class Comment extends Model { use HasFactory; public function commentable() { return $this->morphTo(); } public function votes() { return $this->morphMany(Vote::class, 'voteable'); } }
Abstimmungsmodell:
<?php namespace AppModels; use IlluminateDatabaseEloquentFactoriesHasFactory; use IlluminateDatabaseEloquentModel; class Vote extends Model { use HasFactory; public function voteable() { return $this->morphTo(); } public function user() { return $this->belongsTo(User::class); } }
Der obige Code definiert polymorphe Beziehungen für das Kommentarmodell bzw. das Abstimmungsmodell. Im Comment-Modell verwenden wir die Methode morphTo(), um die polymorphe Assoziation zum Kommentar zu definieren, während wir im Vote-Modell die Methode morphMany() verwenden, um die polymorphe Assoziation zum Kommentar zu definieren.
3. Verwenden Sie polymorphe Assoziationen
Lassen Sie uns sehen, wie man polymorphe Assoziationen verwendet.
Erstellen Sie einen Kommentar:
$article = Article::find(1); $comment = $article->comments()->create([ 'content' => 'This is a comment', ]);
Erhalten Sie Stimmen für einen Kommentar:
$votes = $comment->votes;
Erhalten Sie Kommentare für einen Artikel:
$comments = $article->comments;
Abstimmen:
$comment->votes()->create([ 'user_id' => 1, 'type' => 'up', ]);
Das obige Codebeispiel demonstriert die grundlegende Verwendung polymorpher Assoziationen, die Sie im finden können Laravel Eloquent-Dokumentation Weitere Details zu dieser Funktion.
Zusammenfassung
Polymorphe Assoziation ist eine der wichtigen Funktionen von Laravel Eloquent, die es einem Modell ermöglicht, Beziehungen zu mehreren verschiedenen Modellen aufzubauen. Sehr nützlich beim Datenbankdesign und der Anwendungsentwicklung. Wenn Sie Laravel Eloquent zum Implementieren polymorpher Beziehungen verwenden, müssen Sie die Zwischentabelle der Beziehung entwerfen und die Beziehung im Eloquent-Modell definieren. Wir können die Methoden morphTo() und morphMany() verwenden, um polymorphe Beziehungen zu implementieren.
Das obige ist der detaillierte Inhalt vonLaravel-Entwicklung: Wie implementiert man polymorphe Assoziationen mit Laravel Eloquent?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

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

Heißer Artikel

Heiße Werkzeuge

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

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Methode zum Abholen des Rücksendecode, wenn das Senden von Laravel -E -Mails fehlschlägt. Wenn Sie Laravel zur Entwicklung von Anwendungen verwenden, stellen Sie häufig Situationen auf, in denen Sie Überprüfungscodes senden müssen. Und in Wirklichkeit ...

Laravel -Zeitplan -Aufgabe Ausführen nicht reagierende Fehlerbehebung Bei Verwendung der Zeitplanung von Laravel -Zeitplänen werden viele Entwickler auf dieses Problem stoßen: Zeitplan: Run ...

Die Methode zum Umgang mit Laravels E -Mail -Versagen zum Senden von Verifizierungscode besteht darin, Laravel zu verwenden ...

So implementieren Sie die Tabellenfunktion von benutzerdefiniertem Klicken, um Daten in dcatadmin (laravel-admin) hinzuzufügen, wenn Sie DCAT verwenden ...

Die Auswirkungen des Austauschs von Redis -Verbindungen im Laravel -Framework und der Auswahl von Methoden bei Verwendung von Laravel -Framework und Redis können Entwickler auf ein Problem stoßen: Durch Konfiguration ...

Benutzerdefinierte Mieterdatenbankverbindung in Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis beim Erstellen von Multi-Mandanten-Anwendungen mit Laravel Multi-Tenant-Erweiterungspaket Stanz/Mietverhältnis, ...

Laraveleloquent-Modellab Abruf: Das Erhalten von Datenbankdaten Eloquentorm bietet eine prägnante und leicht verständliche Möglichkeit, die Datenbank zu bedienen. In diesem Artikel werden verschiedene eloquente Modellsuchtechniken im Detail eingeführt, um Daten aus der Datenbank effizient zu erhalten. 1. Holen Sie sich alle Aufzeichnungen. Verwenden Sie die Methode All (), um alle Datensätze in der Datenbanktabelle zu erhalten: UseApp \ Models \ post; $ posts = post :: all (); Dies wird eine Sammlung zurückgeben. Sie können mit der Foreach-Schleife oder anderen Sammelmethoden auf Daten zugreifen: foreach ($ postas $ post) {echo $ post->

Verarbeiten Sie 7 Millionen Aufzeichnungen effizient und erstellen Sie interaktive Karten mit Geospatial -Technologie. In diesem Artikel wird untersucht, wie über 7 Millionen Datensätze mithilfe von Laravel und MySQL effizient verarbeitet und in interaktive Kartenvisualisierungen umgewandelt werden können. Erstes Herausforderungsprojektanforderungen: Mit 7 Millionen Datensätzen in der MySQL -Datenbank wertvolle Erkenntnisse extrahieren. Viele Menschen erwägen zunächst Programmiersprachen, aber ignorieren die Datenbank selbst: Kann sie den Anforderungen erfüllen? Ist Datenmigration oder strukturelle Anpassung erforderlich? Kann MySQL einer so großen Datenbelastung standhalten? Voranalyse: Schlüsselfilter und Eigenschaften müssen identifiziert werden. Nach der Analyse wurde festgestellt, dass nur wenige Attribute mit der Lösung zusammenhängen. Wir haben die Machbarkeit des Filters überprüft und einige Einschränkungen festgelegt, um die Suche zu optimieren. Kartensuche basierend auf der Stadt
