Verschwundene Pivot-Modell-ID (Laravel-Fall-Tagebuch)
Vorgeschichte
Vor kurzem wurde das Back-End-Projekt des Unternehmens von der vorherigen Version laravel5.6 auf die Version laravel5.8 aktualisiert. Nach dem Upgrade generierte das System eine viel SQL-Ausführung Es war falsch, aber es lief gut in der alten Version des Systems, so dass die heutige Reise des Lochgrabens geboren wurde.
Empfohlen: "Laravel-Tutorial"
Projektumgebung
Altes System (Linux + Laravel5.6 + PHP7.2 + mysql5.7)
Das aktualisierte neue System (Linux +laravel5.8 + php7.2 + mysql5.7)
Es wurde nur die Laravel-Framework-Version aktualisiert und andere verwandte Dienste nicht aktualisiert Abhängigkeit.
Aber es ist eine große Anzahl von SQL-Ausführungsfehlern aufgetreten. Die Ausnahmeüberwachung ist wie folgt:
Analyseprozess
Was den Fehler in diesem Dienst verursacht hat, ist ein solches Stück Geschäftslogik, das durch eine Demo unten simuliert wird
$pivot = UserRole::firstOrCreate([ 'user_id' => 3, 'role_id' => 3, ]); $this->addRoleHistory($user,$pivot->id); dd($pivot->id);
In der Laravel 5.6-Version läuft dieser Code problemlos, wird es aber nicht Nach dem Upgrade auf Version 5.8 wurde eine große Anzahl von SQL-Ausführungsfehlern verursacht, wie die folgenden.
laravel5.6: dd($pivot->id); //10002 laravel5.8: dd($pivot->id); //null
Die ID konnte normal aus den in 5.6 gespeicherten Daten abgerufen werden, aber warum funktionierte das nicht? 5.8, also habe ich sofort laravel5.8 überprüft. Den Versionshinweisen zufolge wurde keine Änderung gefunden, die den Erwerb der Auto-Inkrement-ID für das Pivot-Modell abbricht, also begann ich, den 5.8-Quellcode zu überprüfen. . .
Zuerst verglichen wir die firstOrCreate-Funktion von 5.6 und 5.8 und stellten fest, dass es keine Änderungen gab und die Codelogik korrekt ausgeführt wurde.
Lesen Sie dann weiter den Code der Funktion model->save()
und stellen Sie fest, dass die nicht vorhandenen Daten über insertAndSetId eingefügt werden Funktion und der Primärschlüssel ist die festgelegte ID
Aber die insertAndSetId-Funktion wird durch ein Mitgliedsattribut wie Inkrementierung gesteuert. Der Standardwert des Attributs ist true
Wenn dieses Attribut geändert wird, wird der nächste Schritt ausgeführt. Wurde dieses Mitgliedsattribut manipuliert?
Also habe ich sofort den Quellcode des Pivot-Modells von 5.8 überprüft
Schließlich habe ich festgestellt, dass in 5.8 die Inkrementierung standardmäßig auf „false“ eingestellt ist Tabelle Pivot-Klasse, also Die Daten wurden erfolgreich eingefügt, aber die Primärschlüssel-ID nach dem Einfügen wurde nicht festgelegt, was dazu führte, dass die verbleibenden Dienste abstürzten und nicht normal ausgeführt wurden...
Reparaturplan
Überschreiben Sie in jedem Pivot einfach den inkrementierenden Attributwert in der Klasse erneut mit „true“.
class UserRole extends Pivot { public $incrementing = true; protected $fillable = [ 'user_id', 'role_id', ]; }
Nach der Reparatur:
laravel5.8: dd($pivot->id); //10003
Postscript
Also habe ich es mir noch einmal genau angesehen. In den Versionshinweisen zu laravel5.7~laravel5.8 stellte ich fest, dass der Grund für diese Änderung immer noch nicht erwähnt wurde, also ging ich erneut zu Google und konnte den Grund dafür immer noch nicht finden meme.
Am Ende wurden die durch diese Änderung verursachten Probleme erfolgreich behoben und es erinnerte uns auch daran, dass wir der UT-Abdeckung und Versionskompatibilität noch mehr Aufmerksamkeit schenken müssen Änderungstests bei nachfolgenden Versions-Upgrades, um die Projektqualität in mehreren Dimensionen sicherzustellen.
Das obige ist der detaillierte Inhalt vonVerschwundene Pivot-Modell-ID (Laravel-Fall-Tagebuch). 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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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



Datenbankoperationen in PHP werden durch ORM vereinfacht, das Objekte in relationalen Datenbanken abbildet. EloquentORM in Laravel ermöglicht Ihnen die Interaktion mit der Datenbank mithilfe einer objektorientierten Syntax. Sie können ORM verwenden, indem Sie Modellklassen definieren, Eloquent-Methoden verwenden oder in der Praxis ein Blog-System erstellen.

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.

Leitfaden zum Testen von PHP-Einheiten und -Integrationen Unit-Tests: Konzentrieren Sie sich auf eine einzelne Code- oder Funktionseinheit und verwenden Sie PHPUnit, um Testfallklassen zur Überprüfung zu erstellen. Integrationstests: Achten Sie darauf, wie mehrere Codeeinheiten zusammenarbeiten, und verwenden Sie die Methoden setUp() und TearDown() von PHPUnit, um die Testumgebung einzurichten und zu bereinigen. Praktischer Fall: Verwenden Sie PHPUnit, um Unit- und Integrationstests in Laravel-Anwendungen durchzuführen, einschließlich der Erstellung von Datenbanken, dem Starten von Servern und dem Schreiben von Testcode.
