Laravel est un framework Web PHP populaire parmi les développeurs pour ses fonctionnalités puissantes et sa facilité d'utilisation. Dans le développement réel, nous devons souvent supprimer des données de la base de données. Cet article explique comment écrire des suppressions dans Laravel pour vous aider à mieux comprendre et utiliser Laravel.
Laravel propose une variété de méthodes pour supprimer une seule donnée, qui sont présentées ci-dessous.
(1) Utilisez la méthode delete() fournie avec le modèle
Dans Laravel, chaque modèle est livré avec une méthode delete() qui peut être utilisée pour supprimer le enregistrement de base de données correspondant au modèle. Voici un exemple de code de la méthode d'utilisation :
$user = User::find(1); $user->delete();
Dans le code ci-dessus, nous utilisons d'abord la méthode find() du modèle User pour rechercher l'enregistrement avec l'ID 1, puis appelons la suppression () méthode pour supprimer l’enregistrement.
Il est à noter que la méthode delete() ne vérifie pas si d'autres modèles dépendent de l'enregistrement, vous devez donc vous assurer qu'il n'est pas associé à d'autres données avant de supprimer l'enregistrement.
(2) Utilisez la méthode destroy() d'ORM
ORM (Object-Relational Mapping) est un mappage d'objets et de données dans des bases de données relationnelles de technologie Up. Laravel a une fonction ORM intégrée et sa méthode destroy() peut être utilisée pour supprimer les enregistrements de base de données correspondant au modèle.
Ce qui suit est un exemple de code pour supprimer un seul enregistrement à l'aide de la méthode destroy() de l'ORM :
User::destroy(1);
Dans le code ci-dessus, nous appelons directement la méthode destroy() de le modèle Utilisateur et transmettez l'ID de l'enregistrement à supprimer.
Il est à noter que la méthode destroy() ne vérifie pas si d'autres modèles dépendent de l'enregistrement, vous devez donc vous assurer qu'il n'est pas associé à d'autres données avant de supprimer l'enregistrement.
(3) Utilisez la méthode delete() de Query Builder
Query Builder est un générateur d'instructions SQL dans Laravel basé sur des appels chaînés. Il fournit une multitude de méthodes pour faire fonctionner la base de données, y compris la méthode delete() pour supprimer des données.
Ce qui suit est un exemple de code pour supprimer un seul enregistrement à l'aide de la méthode delete() de Query Builder :
DB::table('users')->where('id', 1)->delete();
Dans le code ci-dessus, nous utilisons la façade DB (base de données) pour appelez la méthode table() Spécifiez le nom de la table de données à supprimer, puis utilisez la méthodewhere() pour spécifier les conditions à supprimer, et enfin appelez la méthode delete() pour effectuer l'opération de suppression.
Il est à noter que la méthode delete() ne déclenchera pas les événements et les hooks du modèle, donc si vous utilisez ces fonctions, il est recommandé d'utiliser l'une des méthodes ci-dessus.
En plus de supprimer des enregistrements de base de données uniques, Laravel fournit également une méthode pratique pour supprimer des données par lots. Ce qui suit est une introduction à deux méthodes de suppression par lots couramment utilisées.
(1) Utilisez la méthode delete() d'ORM
La méthode delete() d'ORM peut non seulement supprimer un seul enregistrement, mais également supprimer plusieurs enregistrements par lots. Voici un exemple de code qui utilise cette méthode pour supprimer des enregistrements par lots :
User::where('age', '>', 18)->delete();
Dans le code ci-dessus, nous utilisons d'abord la méthode Where() pour filtrer les utilisateurs de plus de 18 ans, puis appelez la méthode delete() pour supprimer ces enregistrements.
Il est à noter que la méthode delete() ne déclenchera pas les événements et les hooks du modèle, donc si vous utilisez ces fonctions, il est recommandé d'utiliser l'une des méthodes ci-dessus.
(2) Utilisez la méthode delete() de Query Builder
La méthode delete() de Query Builder peut également être utilisée pour supprimer des enregistrements par lots. Voici un exemple de code qui utilise cette méthode pour supprimer des enregistrements par lots :
DB::table('users')->where('age', '>', 18)->delete();
Dans le code ci-dessus, nous utilisons la méthode Where() pour spécifier les conditions à supprimer, et utilisons la méthode delete( ) méthode pour effectuer l’opération de suppression.
Il est à noter que la méthode delete() ne déclenchera pas les événements et les hooks du modèle, donc si vous utilisez ces fonctions, il est recommandé d'utiliser l'une des méthodes ci-dessus.
Dans le développement réel, nous devons parfois conserver des enregistrements des données supprimées pour une récupération ultérieure. À ce stade, Soft Delete est utile. Laravel dispose d'une fonction de suppression logicielle intégrée qui nous aide à supprimer les données de manière sûre.
L'idée principale de la mise en œuvre de la suppression logicielle est d'ajouter un champ delete_at à la table de la base de données pour enregistrer l'heure de suppression. Lors de l'interrogation des données, Laravel filtrera automatiquement les enregistrements supprimés de manière logicielle afin qu'ils ne soient pas affichés dans les résultats de la requête.
Ce qui suit est un exemple de code pour implémenter la suppression logicielle à l'aide de Laravel :
Tout d'abord, vous devez utiliser le trait SoftDeletes dans le modèle :
<?php namespace App; use IlluminateDatabaseEloquentModel; use IlluminateDatabaseEloquentSoftDeletes; class User extends Model { use SoftDeletes; }
Schema::table('users', function (Blueprint $table) { $table->softDeletes(); });
$user = User::find(1); $user->delete();
$user = User::withTrashed()->find(1); $user->restore();
Laravel propose une multitude de méthodes pour supprimer des données, et vous pouvez choisir différentes méthodes en fonction des besoins spécifiques de votre entreprise. Dans le développement réel, nous devons soigneusement réfléchir à l'opportunité d'utiliser des opérations telles que la suppression logicielle ou la suppression par lots en fonction de la situation pour garantir l'intégrité et la sécurité des données. Dans le même temps, il convient de noter que la suppression de données peut affecter le fonctionnement normal d'autres modèles ou fonctions, et que des tests et des vérifications suffisants sont nécessaires.
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!