Maison > cadre php > Laravel > méthode d'écriture de suppression laravel

méthode d'écriture de suppression laravel

WBOY
Libérer: 2023-05-26 13:46:07
original
1837 Les gens l'ont consulté

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.

  1. Supprimer une seule donnée

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();
Copier après la connexion
Copier après la connexion

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);
Copier après la connexion

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();
Copier après la connexion

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.

  1. Supprimer les données par lots

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();
Copier après la connexion

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();
Copier après la connexion

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.

  1. Suppression logicielle

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;
}
Copier après la connexion
#🎜🎜 #Ensuite, dans la base de données Ajoutez le champ delete_at dans la migration :

Schema::table('users', function (Blueprint $table) {
    $table->softDeletes();
});
Copier après la connexion

Enfin, utilisez la méthode delete() dans le contrôleur pour supprimer automatiquement les données :

$user = User::find(1);
$user->delete();
Copier après la connexion
Copier après la connexion

If vous devez récupérer les données supprimées, vous pouvez utiliser la méthode restaurer() :

$user = User::withTrashed()->find(1);
$user->restore();
Copier après la connexion
La suppression logicielle peut nous aider à mieux gérer les données supprimées sans nous soucier d'une suppression accidentelle de données. Cependant, il convient de noter que la suppression logicielle n'est pas une solution universelle. Dans certains scénarios commerciaux, les données doivent être complètement supprimées pour garantir leur intégrité et leur sécurité.

résumé

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal