ID du modèle Pivot disparu (journal des pièges de Laravel)
Antécédents
Récemment, le projet back-end de l'entreprise a été mis à niveau et mis à niveau de la version précédente de laravel5.6 vers la version laravel5.8. Après la mise à niveau, le système a généré un. beaucoup d'exécution SQL C'était faux, mais cela fonctionnait bien dans l'ancienne version du système, c'est pourquoi le voyage actuel consistant à creuser des trous est né.
Recommandé : "Tutoriel Laravel"
Environnement du projet
Ancien système (linux + laravel5.6 + php7.2 + mysql5.7)
Le nouveau système mis à niveau (linux +laravel5.8 + php7.2 + mysql5.7)
Mise à niveau uniquement de la version du framework Laravel et n'a pas mis à niveau les autres services associés Dépendance.
Mais un grand nombre d'erreurs d'exécution SQL se sont produites. Le suivi des exceptions est le suivant :
Processus d'analyse
Ce qui a causé l'erreur dans ce service est un tel élément de logique métier, qui est simulé via une démo ci-dessous
$pivot = UserRole::firstOrCreate([ 'user_id' => 3, 'role_id' => 3, ]); $this->addRoleHistory($user,$pivot->id); dd($pivot->id);
Dans la version laravel 5.6, ce code s'exécute sans aucun problème, mais il ne le fera pas. fonctionner après la mise à niveau vers la version 5.8. Un grand nombre d'erreurs d'exécution SQL ont été provoquées, comme les suivantes.
laravel5.6: dd($pivot->id); //10002 laravel5.8: dd($pivot->id); //null
L'ID pouvait être obtenu normalement à partir des données enregistrées dans la version 5.6, mais pourquoi ne pouvait-il pas fonctionner dans la version 5.8. 5.8, j'ai donc immédiatement vérifié laravel5.8. Selon les notes de version, aucun changement n'a été trouvé pour annuler l'acquisition de l'ID d'incrémentation automatique pour le modèle Pivot, j'ai donc commencé à vérifier le code source 5.8. . .
Tout d'abord, nous avons comparé la fonction firstOrCreate de 5.6 et 5.8 et avons constaté qu'il n'y avait aucun changement et que la logique du code était exécutée correctement.
Continuez ensuite à lire le code de la fonction model->save()
et constatez que les données inexistantes sont insérées via insertAndSetId fonction et la clé primaire est set ID
Mais la fonction insertAndSetId est contrôlée via un attribut membre comme l'incrémentation. La valeur par défaut de l'attribut est true
.
Lorsque cet attribut est modifié, l'étape suivante sera exécutée. Cet attribut de membre a-t-il été manipulé ?
J'ai donc immédiatement vérifié le code source du modèle pivot de 5.8
Enfin, j'ai découvert qu'en 5.8, l'incrémentation est définie sur false par défaut dans l'intermédiaire. Classe Pivot de la table, donc les données ont été insérées avec succès, mais l'ID de clé primaire après l'insertion n'a pas été défini, ce qui a provoqué le blocage des services restants et leur échec de fonctionnement normal...
Plan de réparation
Dans chaque pivot, réécrivez simplement la valeur de l'attribut incrémentiel dans la classe sur true.
class UserRole extends Pivot { public $incrementing = true; protected $fillable = [ 'user_id', 'role_id', ]; }
Après réparation :
laravel5.8: dd($pivot->id); //10003
Postscript
Je l'ai donc regardé attentivement à nouveau. Dans les notes de version de laravel5.7~laravel5.8, j'ai découvert que la raison de ce changement n'était toujours pas mentionnée, alors je suis retourné sur Google et je n'ai toujours pas trouvé la raison de ce changement. meme.
Au final, les problèmes causés par ce changement ont été résolus avec succès, et cela nous a également rappelé que nous devons encore accorder plus d'attention à la couverture UT et à la compatibilité des versions. modifier les tests dans les mises à niveau de versions ultérieures pour garantir la qualité du projet dans plusieurs dimensions.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

PHP et Flutter sont des technologies populaires pour le développement mobile. Flutter excelle dans les capacités multiplateformes, les performances et l'interface utilisateur, et convient aux applications qui nécessitent des performances élevées, une interface utilisateur multiplateforme et personnalisée. PHP convient aux applications côté serveur avec des performances inférieures et non multiplateformes.

Les opérations de base de données en PHP sont simplifiées à l'aide d'ORM, qui mappe les objets dans des bases de données relationnelles. EloquentORM dans Laravel vous permet d'interagir avec la base de données en utilisant une syntaxe orientée objet. Vous pouvez utiliser ORM en définissant des classes de modèle, en utilisant des méthodes Eloquent ou en créant un système de blog dans la pratique.

Laravel - Artisan Commands - Laravel 5.7 est livré avec une nouvelle façon de traiter et de tester de nouvelles commandes. Il inclut une nouvelle fonctionnalité de test des commandes artisanales et la démonstration est mentionnée ci-dessous ?

Analyse de l'outil de test unitaire PHP : PHPUnit : convient aux grands projets, fournit des fonctionnalités complètes et est facile à installer, mais peut être verbeux et lent. PHPUnitWrapper : adapté aux petits projets, facile à utiliser, optimisé pour Lumen/Laravel, mais a des fonctionnalités limitées, ne fournit pas d'analyse de couverture de code et dispose d'un support communautaire limité.

Les dernières versions de Laravel 9 et CodeIgniter 4 fournissent des fonctionnalités et des améliorations mises à jour. Laravel9 adopte l'architecture MVC et fournit des fonctions telles que la migration de bases de données, l'authentification et le moteur de modèles. CodeIgniter4 utilise l'architecture HMVC pour fournir le routage, l'ORM et la mise en cache. En termes de performances, le modèle de conception basé sur le fournisseur de services de Laravel9 et le framework léger de CodeIgniter4 lui confèrent d'excellentes performances. Dans les applications pratiques, Laravel9 convient aux projets complexes qui nécessitent de la flexibilité et des fonctions puissantes, tandis que CodeIgniter4 convient au développement rapide et aux petites applications.

Comparez les capacités de traitement des données de Laravel et CodeIgniter : ORM : Laravel utilise EloquentORM, qui fournit un mappage relationnel classe-objet, tandis que CodeIgniter utilise ActiveRecord pour représenter le modèle de base de données en tant que sous-classe de classes PHP. Générateur de requêtes : Laravel dispose d'une API de requêtes chaînées flexible, tandis que le générateur de requêtes de CodeIgniter est plus simple et basé sur des tableaux. Validation des données : Laravel fournit une classe Validator qui prend en charge les règles de validation personnalisées, tandis que CodeIgniter a moins de fonctions de validation intégrées et nécessite un codage manuel des règles personnalisées. Cas pratique : l'exemple d'enregistrement d'utilisateur montre Lar

Guide des tests unitaires et d'intégration PHP Tests unitaires : concentrez-vous sur une seule unité de code ou de fonction et utilisez PHPUnit pour créer des classes de cas de test à des fins de vérification. Tests d'intégration : faites attention à la façon dont plusieurs unités de code fonctionnent ensemble et utilisez les méthodes setUp() et TearDown() de PHPUnit pour configurer et nettoyer l'environnement de test. Cas pratique : utilisez PHPUnit pour effectuer des tests unitaires et d'intégration dans les applications Laravel, notamment la création de bases de données, le démarrage de serveurs et l'écriture de code de test.

Lors du choix d'un framework pour de grands projets, Laravel et CodeIgniter ont chacun leurs propres avantages. Laravel est conçu pour les applications d'entreprise, offrant une conception modulaire, une injection de dépendances et un ensemble de fonctionnalités puissantes. CodeIgniter est un framework léger plus adapté aux projets de petite et moyenne taille, mettant l'accent sur la rapidité et la facilité d'utilisation. Pour les grands projets avec des exigences complexes et un grand nombre d'utilisateurs, la puissance et l'évolutivité de Laravel sont plus adaptées. Pour les projets simples ou les situations avec des ressources limitées, les capacités de développement légères et rapides de CodeIgniter sont plus idéales.
