Maison cadre php Laravel Une brève analyse de la façon dont les données supprimées de manière logicielle dans Laravel peuvent toujours être lues

Une brève analyse de la façon dont les données supprimées de manière logicielle dans Laravel peuvent toujours être lues

Apr 03, 2023 pm 07:41 PM

Laravel est un framework d'application Web PHP populaire qui fournit de nombreuses fonctionnalités et outils puissants qui simplifient le processus de développement d'applications Web. Parmi eux, la fonction de suppression logicielle de Laravel est une fonctionnalité très utile. Elle peut répondre à certains besoins particuliers tout en conservant l'intégrité des données en marquant les enregistrements comme supprimés au lieu de supprimer immédiatement les enregistrements de la base de données.

Cependant, une question que de nombreux développeurs Laravel ont pu rencontrer est la suivante : les données supprimées de manière logicielle peuvent-elles toujours être lues ? Dans cet article, nous explorerons ce problème et ses solutions.

Tout d’abord, vous devez comprendre le principe de la suppression logicielle dans Laravel. La suppression logicielle est implémentée en ajoutant un champ delete_at à la table de données. Lors de l'utilisation de la suppression logicielle, lorsqu'un enregistrement est supprimé, Laravel définit simplement le champ delete_at de l'enregistrement sur une valeur non vide au lieu de supprimer l'enregistrement, obtenant ainsi l'effet de « suppression logicielle ». Lors de l'interrogation de données, Laravel filtrera automatiquement les enregistrements avec un champ delete_at non vide pour obtenir l'effet d'interroger uniquement les enregistrements qui n'ont pas été « supprimés en douceur ».

Par conséquent, les données supprimées de manière logicielle peuvent toujours être lues, même si les enregistrements supprimés de manière logicielle existent toujours dans la base de données. Cependant, par défaut, la suppression logicielle de Laravel filtrera automatiquement uniquement les enregistrements marqués comme « supprimés automatiquement ». Si vous devez interroger à la fois les enregistrements supprimés et non supprimés, vous devez ajouter manuellement la méthode withTrashed à la requête. La méthode

withTrashed renvoie les enregistrements supprimés de manière logicielle, tandis que l'interrogation des enregistrements non supprimés de manière logicielle utilise toujours la méthode habituelle :

// 查询未被软删除的记录
$users = DB::table('users')->whereNull('deleted_at')->get();

// 查询被软删除的记录
$trashedUsers = DB::table('users')->whereNotNull('deleted_at')->get();

// 同时查询未被软删除和被软删除的记录
$usersWithTrashed = DB::table('users')->withTrashed()->get();
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé les méthodes WhereNull et WhereNotNull pour interroger les enregistrements non supprimés et supprimés, à en même temps, la méthode withTrashed est également utilisée pour interroger les enregistrements supprimés de manière logicielle.

En plus de la méthode withTrashed, Laravel fournit également deux autres méthodes : onlyTrashed et restaurer, qui sont utilisées pour interroger les enregistrements supprimés de manière logicielle et restaurer les enregistrements supprimés de manière logicielle. L'utilisation est la suivante :

// 查询被软删除的记录
$trashedUsers = DB::table('users')->onlyTrashed()->get();

// 恢复软删除的记录
DB::table('users')->where('id', $id)->restore();
Copier après la connexion

En résumé, les données Laravel supprimées de manière logicielle peuvent toujours être lues, mais par défaut, seuls les enregistrements qui n'ont pas été supprimés de manière logicielle sont interrogés. Si vous devez interroger simultanément les enregistrements supprimés et non supprimés, vous devez ajouter manuellement la méthode withTrashed. En outre, vous pouvez également utiliser la méthode onlyTrashed pour interroger les enregistrements supprimés de manière logicielle et la méthode de restauration pour restaurer les enregistrements supprimés de manière logicielle. La maîtrise de ces méthodes peut permettre aux développeurs de mieux appliquer la fonction de suppression logicielle de Laravel et d'améliorer l'efficacité du développement.

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

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

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.

Laravel et le backend: alimentation logique d'application Web Laravel et le backend: alimentation logique d'application Web Apr 11, 2025 am 11:29 AM

Comment Laravel joue-t-il un rôle dans la logique backend? Il simplifie et améliore le développement backend par le biais de systèmes de routage, d'éloquente, d'authentification et d'autorisation, d'événements et d'auditeurs et d'optimisation des performances. 1. Le système de routage permet la définition de la structure d'URL et demande la logique de traitement. 2.Lao-éloquente simplifie l'interaction de la base de données. 3. Le système d'authentification et d'autorisation est pratique pour la gestion des utilisateurs. 4. L'événement et l'écoute implémentent la structure de code couplée de manière lâche. 5. L'optimisation des performances améliore l'efficacité de l'application par la mise en cache et la file d'attente.

Quel est le meilleur PHP ou Laravel? Quel est le meilleur PHP ou Laravel? Mar 27, 2025 pm 05:31 PM

PHP et Laravel ne sont pas directement comparables, car Laravel est un cadre basé sur PHP. 1.Php convient aux petits projets ou à un prototypage rapide car il est simple et direct. 2. Laravel convient à de grands projets ou à un développement efficace car il offre des fonctions et des outils riches, mais a une courbe d'apprentissage abrupte et peut ne pas être aussi bon que PHP pur.

Exemple d'introduction de Laravel Exemple d'introduction de Laravel Apr 18, 2025 pm 12:45 PM

Laravel est un cadre PHP pour la création facile des applications Web. Il fournit une gamme de fonctionnalités puissantes, notamment: Installation: Installez le Laravel CLI globalement avec Composer et créez des applications dans le répertoire du projet. Routage: définissez la relation entre l'URL et le gestionnaire dans Routes / web.php. Voir: Créez une vue dans les ressources / vues pour rendre l'interface de l'application. Intégration de la base de données: fournit une intégration prête à l'emploi avec des bases de données telles que MySQL et utilise la migration pour créer et modifier des tables. Modèle et contrôleur: le modèle représente l'entité de la base de données et le contrôleur traite les demandes HTTP.

Laravel est-il un frontend ou un backend? Laravel est-il un frontend ou un backend? Mar 27, 2025 pm 05:31 PM

LaravelisabackendFrameworkBuiltonPhp, conçue pourwebapplicationdevelopment.itfocusonServer-sidelogic, databasemanagement, andapplicationsstructure, andcanbenegrategratedwithfrontentechnologies likevue.jsorrectForfull-stackdevelopment.

Comment apprendre Laravel comment apprendre Laravel gratuitement Comment apprendre Laravel comment apprendre Laravel gratuitement Apr 18, 2025 pm 12:51 PM

Vous voulez apprendre le cadre de Laravel, mais ne souffrez pas de ressources ni de pression économique? Cet article vous fournit un apprentissage gratuit de Laravel, vous apprenant à utiliser des ressources telles que les plateformes en ligne, les documents et les forums communautaires pour jeter une base solide pour votre parcours de développement PHP de la mise en place de maîtrise.

Polyvylity de Laravel: des sites simples aux systèmes complexes Polyvylity de Laravel: des sites simples aux systèmes complexes Apr 13, 2025 am 12:13 AM

Le projet de développement de Laravel a été choisi en raison de sa flexibilité et de sa puissance pour répondre aux besoins de différentes tailles et complexités. Laravel fournit un système de routage, Eloquentorm, une ligne de commande artisanale et d'autres fonctions, soutenant le développement de blogs simples aux systèmes complexes au niveau de l'entreprise.

Fonction de connexion de l'utilisateur de Laravel Fonction de connexion de l'utilisateur de Laravel Apr 18, 2025 pm 12:48 PM

Laravel fournit un cadre Auth complet pour implémenter les fonctions de connexion des utilisateurs, notamment: définir des modèles d'utilisateurs (modèle éloquent), créant des formulaires de connexion (moteur de modèle de lame), rédaction des contrôleurs de connexion (héritage de l'authentification \ loginContrôleur), vérifiant les demandes de connexion (Auth :: tentative) Redirection après la connexion de la connexion, la limitation de la sécurité). De plus, le cadre Auth fournit également des fonctions telles que la réinitialisation des mots de passe, l'enregistrement et la vérification des e-mails. Pour plus de détails, veuillez consulter la documentation de Laravel: https://laravel.com/doc

See all articles