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

méthode d'écriture de suppression laravel

May 26, 2023 pm 01:46 PM

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment utiliser les composants de Laravel pour créer des éléments d'interface utilisateur réutilisables? Comment utiliser les composants de Laravel pour créer des éléments d'interface utilisateur réutilisables? Mar 17, 2025 pm 02:47 PM

L'article discute de la création et de la personnalisation des éléments d'interface utilisateur réutilisables dans Laravel à l'aide de composants, offrant les meilleures pratiques pour l'organisation et suggérant des packages améliorant.

Quelles sont les meilleures pratiques pour utiliser Laravel dans un environnement natif du cloud? Quelles sont les meilleures pratiques pour utiliser Laravel dans un environnement natif du cloud? Mar 14, 2025 pm 01:44 PM

L'article traite des meilleures pratiques pour déployer Laravel dans des environnements natifs du cloud, en se concentrant sur l'évolutivité, la fiabilité et la sécurité. Les problèmes clés incluent la conteneurisation, les microservices, la conception sans état et les stratégies d'optimisation.

Comment créer et utiliser des directives de lame personnalisées à Laravel? Comment créer et utiliser des directives de lame personnalisées à Laravel? Mar 17, 2025 pm 02:50 PM

L'article discute de la création et de l'utilisation des directives de lame personnalisées à Laravel pour améliorer les modèles. Il couvre la définition des directives, les utilisant dans des modèles et les gérer dans de grands projets, mettant en évidence des avantages tels que l'amélioration de la réutilisabilité du code et R

Comment puis-je créer et utiliser des règles de validation personnalisées dans Laravel? Comment puis-je créer et utiliser des règles de validation personnalisées dans Laravel? Mar 17, 2025 pm 02:38 PM

L'article discute de la création et de l'utilisation de règles de validation personnalisées dans Laravel, offrant des étapes pour les définir et les mettre en œuvre. Il met en évidence des avantages tels que la réutilisabilité et la spécificité et fournit des méthodes pour étendre le système de validation de Laravel.

Comment utiliser la console artisanale de Laravel pour automatiser les tâches courantes? Comment utiliser la console artisanale de Laravel pour automatiser les tâches courantes? Mar 17, 2025 pm 02:39 PM

La console artisanale de Laravel automatise des tâches comme la génération de code, l'exécution de migrations et la planification. Les commandes clés incluent la marque: contrôleur, migrer et db: graines. Les commandes personnalisées peuvent être créées pour des besoins spécifiques, améliorant l'efficacité du flux de travail.

Comment puis-je utiliser les fonctionnalités de routage de Laravel pour créer des URL adaptées au référencement? Comment puis-je utiliser les fonctionnalités de routage de Laravel pour créer des URL adaptées au référencement? Mar 17, 2025 pm 02:43 PM

L'article discute de l'utilisation du routage de Laravel pour créer des URL conviviales, couvrant les meilleures pratiques, des URL canoniques et des outils pour l'optimisation du référencement. Nombre de mots: 159

Comment Laravel se compare-t-il aux autres cadres PHP (Symfony, Codeigniter, YII)? Comment Laravel se compare-t-il aux autres cadres PHP (Symfony, Codeigniter, YII)? Mar 14, 2025 pm 01:49 PM

Laravel, connu pour sa syntaxe élégante, est comparée à Symfony, Codeigniter et YII. Il offre une courbe d'apprentissage plus douce et des fonctionnalités uniques comme Eloquent Orm et Artisan CLI, équilibrant la facilité d'utilisation avec des fonctionnalités robustes.

Quel est le meilleur, Django ou Laravel? Quel est le meilleur, Django ou Laravel? Mar 28, 2025 am 10:41 AM

Django et Laravel sont tous deux des frameworks à pile. Django convient aux développeurs Python et à la logique métier complexe, tandis que Laravel convient aux développeurs PHP et à la syntaxe élégante. 1.Django est basé sur Python et suit la philosophie "Battery-Complete", adaptée au développement rapide et à une grande concurrence. 2.Laravel est basé sur PHP, mettant l'accent sur l'expérience du développeur et convient aux projets de petite et moyenne taille.

See all articles