Maison cadre php Laravel Comment implémenter la fonction de suppression par lots dans Laravel

Comment implémenter la fonction de suppression par lots dans Laravel

Apr 11, 2023 pm 03:07 PM

À mesure que les applications web deviennent de plus en plus populaires, la gestion des données est devenue une technologie incontournable. Cependant, gérer de grandes quantités de données peut s’avérer une tâche fastidieuse, notamment lorsqu’il s’agit de suppressions. Heureusement, le framework Laravel fournit un moyen simple mais efficace de gérer les opérations de suppression groupée de données. Dans cet article, nous apprendrons comment implémenter la suppression par lots dans Laravel, vous rendant plus flexible et efficace lors du traitement de grandes quantités de données.

Étape 1 : Configurer le modèle

Avant de commencer, nous devons nous assurer que nous disposons d'une classe de modèle pour la gestion des tables de base de données. Par exemple, créons une classe de modèle admin pour gérer la table admins. Nous pouvons générer ce modèle en utilisant la commande suivante :

php artisan make:model Admin
Copier après la connexion

Cela créera un fichier Admin.php dans le répertoire de l'application contenant les classes de modèle pour gérer la table admins.

Étape 2 : Ajouter une méthode de suppression

Maintenant, ajoutons une méthode pour supprimer notre administrateur. Ajoutez le code suivant dans notre classe de modèle d'administration :

public static function deleteByIds(array $ids)
{
    return self::whereIn('id', $ids)->delete();
}
Copier après la connexion

Dans cette méthode, nous utilisons la méthode WhereIn() de Laravel pour trouver les enregistrements qui correspondent au tableau d'ID transmis. Enfin, nous utilisons la méthode delete() pour supprimer les enregistrements correspondants.

Étape 3 : Créer un contrôleur

Maintenant, nous devons créer une classe de contrôleur pour gérer notre demande de suppression de données. Nous pouvons générer ce contrôleur en utilisant la commande suivante :

php artisan make:controller AdminController --resource
Copier après la connexion

Cela créera un fichier AdminController.php dans le répertoire app/Http/Controllers, qui contient une classe de contrôleur de ressources.

Étape 4 : Définir les itinéraires

Ensuite, nous devons définir les itinéraires pour la suppression groupée des administrateurs. Ajoutez le code suivant à notre fichier web.php :

Route::delete('/admins/delete', 'AdminController@delete')->name('admins.delete');
Copier après la connexion

Cela créera une route pour gérer les requêtes effectuées par la méthode delete() dans notre classe AdminController. Nous nommerons également la route admins.delete afin de pouvoir la référencer ultérieurement dans la vue.

Étape 5 : Créer une vue

Enfin, nous devons créer une vue qui affiche tous les enregistrements administratifs disponibles et permet à l'utilisateur de sélectionner les enregistrements qui doivent être supprimés. Nous pouvons utiliser le code suivant pour créer cette vue :

@extends('layouts.app')

@section('content')
    <form action="{{route(&#39;admins.delete&#39;)}}" method="POST">
        @csrf
        @method('delete')

        <button type="submit" class="btn btn-primary mb-2">Delete Selected</button>

        <table class="table">
            <thead>
            <tr>
                <th scope="col">#</th>
                <th scope="col">Name</th>
                <th scope="col">Email</th>
                <th scope="col">Actions</th>
            </tr>
            </thead>
            <tbody>
            @foreach ($admins as $admin)
                <tr>
                    <th scope="row">{{ $admin->id }}</th>
                    <td>{{ $admin->name }}</td>
                    <td>{{ $admin->email }}</td>
                    <td>
                        <input type="checkbox" name="ids[]" value="{{ $admin->id }}">
                    </td>
                </tr>
            @endforeach
            </tbody>
        </table>
    </form>
@endsection
Copier après la connexion

Dans cette vue, nous créons un tableau avec tous les enregistrements administratifs. Nous avons également ajouté une case à cocher qui permet à l'utilisateur de sélectionner les enregistrements à supprimer, ainsi qu'un bouton de soumission qui appelle l'itinéraire de suppression que nous avons défini à l'étape précédente. Cette vue doit être enregistrée dans le fichier resources/views/admins/index.blade.php.

Étape 6 : Gérer les demandes de suppression

Maintenant que nos itinéraires et nos vues sont configurés, nous devons ajouter une méthode dans notre classe de contrôleur pour gérer les demandes de suppression groupées :

public function delete(Request $request)
{
    $ids = $request->ids;
    Admin::deleteByIds($ids);

    return redirect()->back()->with('success', 'Selected admins have been deleted!');
}
Copier après la connexion

Dans cette méthode, nous obtenons tous les éléments sélectionnés. Enregistrez les identifiants. et transmettez-les à la méthode deleteByIds() que nous avons définie dans la classe modèle. Enfin, nous revenons à notre vue et affichons un message de réussite.

Résumé

Dans cet article, nous avons appris comment supprimer des enregistrements de base de données par lots à l'aide du framework Laravel. Nous avons créé une classe de modèle et une classe de contrôleur pour gérer les données, défini un itinéraire pour gérer les demandes de suppression et créé une vue pour afficher les données et gérer les entrées de l'utilisateur. Vous disposez désormais d'un outil puissant pour gérer les données de votre application Web, vous rendant plus flexible et efficace.

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)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
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.

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

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.

Comment utiliser les transactions de base de données dans Laravel pour assurer la cohérence des données? Comment utiliser les transactions de base de données dans Laravel pour assurer la cohérence des données? Mar 17, 2025 pm 02:37 PM

L'article discute de l'utilisation des transactions de base de données dans Laravel pour maintenir la cohérence des données, des méthodes de détail avec une façade DB et des modèles éloquents, les meilleures pratiques, la gestion des exceptions et les outils de surveillance et de débogage des transactions.

Comment puis-je implémenter la mise en cache dans Laravel pour améliorer les performances des applications? Comment puis-je implémenter la mise en cache dans Laravel pour améliorer les performances des applications? Mar 17, 2025 pm 02:35 PM

L'article discute de la mise en œuvre de la mise en cache dans Laravel pour augmenter les performances, couvrant la configuration, en utilisant la façade de cache, les balises de cache et les opérations atomiques. Il décrit également les meilleures pratiques pour la configuration du cache et suggère des types de données à cache

See all articles