Maison > cadre php > Laravel > Comment utiliser la classe DB Laravel

Comment utiliser la classe DB Laravel

王林
Libérer: 2023-05-26 14:11:37
original
1085 Les gens l'ont consulté

Laravel est un framework Web PHP populaire privilégié par les développeurs pour sa syntaxe élégante, son développement pratique et ses performances efficaces. Dans le développement de Laravel, les opérations de base de données sont particulièrement importantes. Laravel fournit une classe DB pour exploiter les bases de données. Cet article présentera en détail l'utilisation de la classe Laravel DB.

  1. Utilisation de base de la classe DB

Dans le développement Laravel, nous pouvons facilement effectuer des opérations de base de données via la classe DB. Avant d'utiliser la classe DB, vous devez introduire l'espace de noms dans le contrôleur :

use IlluminateSupportFacadesDB;
Copier après la connexion

Grâce à la classe DB, nous pouvons effectuer des opérations telles que des requêtes, des insertions, des mises à jour, des suppressions, etc. Voici un exemple de requête de base de données :

$users = DB::table('users')->get();
Copier après la connexion

L'exemple ci-dessus consiste à obtenir les enregistrements de tous les utilisateurs à partir de la table des utilisateurs. Si vous souhaitez obtenir un seul enregistrement, vous pouvez utiliser le code suivant :

$user = DB::table('users')->where('name', 'John')->first();
Copier après la connexion

Le code ci-dessus obtiendra le premier enregistrement nommé John de la table des utilisateurs.

  1. Constructeur de requête de la classe DB

La clé de la classe DB est le constructeur de requête. Le générateur de requêtes peut créer des requêtes via des méthodes en chaîne, ce qui est très flexible et pratique. Voici quelques exemples :

a. requête conditionnelle

$users = DB::table('users')->where('name', '=', 'John')->get();
Copier après la connexion

L'exemple ci-dessus interroge les enregistrements dont le nom est égal à « John » dans la table des utilisateurs. Le type de condition peut être spécifié via le deuxième paramètre, tel que '>', '<', '>=', '<=', etc.

b. orWhere condition query

$users = DB::table('users')->where('name', '=', 'John')->orWhere('name', '=', 'Mary')->get();
Copier après la connexion

L'exemple ci-dessus consiste à interroger les enregistrements dont le nom est égal à « John » ou « name » est égal à « Mary » du tableau des utilisateurs.

c. Requête de condition Where multiple

$users = DB::table('users')->where([
    ['status', '=', '1'],
    ['name', '<>', 'John']
])->get();
Copier après la connexion

L'exemple ci-dessus consiste à interroger les enregistrements avec un statut égal à 1 et un nom différent de John dans la table des utilisateurs.

d.whereBetween condition query

$users = DB::table('users')->whereBetween('votes', [1, 100])->get();
Copier après la connexion

L'exemple ci-dessus consiste à interroger les enregistrements de votes compris entre 1 et 100 dans la table des utilisateurs.

e. requête conditionnelle WhereIn

$users = DB::table('users')->whereIn('id', [1, 2, 3])->get();
Copier après la connexion

L'exemple ci-dessus consiste à interroger les enregistrements avec les ID 1, 2 et 3 de la table des utilisateurs.

f. orderBy sort query

$users = DB::table('users')->orderBy('name', 'desc')->get();
Copier après la connexion

L'exemple ci-dessus consiste à interroger les enregistrements de la table des utilisateurs dans l'ordre inverse par nom.

  1. Opérations d'insertion, de mise à jour et de suppression de la classe DB

La classe DB Laravel prend non seulement en charge les opérations de requête, mais prend également en charge l'insertion, la mise à jour, et supprimer les opérations. Voici quelques exemples :

a. Insertion de données

DB::table('users')->insert([
    'email' => 'john@example.com',
    'name' => 'John Doe'
]);
Copier après la connexion

L'exemple ci-dessus insère un enregistrement avec l'adresse e-mail john@example.com et le nom John Doe dans la table des utilisateurs.

b. Mise à jour des données

DB::table('users')->where('id', 1)->update(['votes' => 1]);
Copier après la connexion

L'exemple ci-dessus met à jour le nombre de votes de l'utilisateur avec l'identifiant 1 à 1.

c. Suppression des données

DB::table('users')->where('votes', '<', 100)->delete();
Copier après la connexion

L'exemple ci-dessus supprime tous les utilisateurs avec des votes inférieurs à 100.

  1. Opération de transaction de classe DB

Pendant le processus d'opération des données, des accidents sont susceptibles de se produire, tels que des erreurs lors de l'insertion des données. À ce stade, la transaction doit être annulée pour garantir l'intégrité des données. Les classes Laravel DB prennent en charge les opérations de transaction. Voici un exemple :

DB::transaction(function () {
    DB::table('users')->update(['votes' => 1]);
    DB::table('posts')->delete();
});
Copier après la connexion

L'exemple ci-dessus est une transaction simple qui met à jour le nombre de votes de tous les utilisateurs dans la table des utilisateurs à 1 et supprime tous les enregistrements de la table des publications. Si une erreur se produit lors d'une transaction, elle est automatiquement annulée et l'intégrité des données est maintenue.

  1. Connexion et nom de la table de la classe DB

Dans la plupart des cas, la classe Laravel DB se connectera automatiquement à la base de données et à la table par défaut, mais dans dans certains cas, nous devons spécifier manuellement la connexion et le nom de la table. Voici un exemple :

$users = DB::connection('connection-1')->table('users')->get();
Copier après la connexion

L'exemple ci-dessus affiche toutes les données de la table des utilisateurs lors de la première connexion. Nous pouvons configurer plusieurs informations de connexion dans le fichier config/database.php.

  1. Conclusion

Grâce à la classe Laravel DB, nous pouvons facilement effectuer des opérations de base de données. Des simples requêtes de données aux opérations de transaction complexes, les classes Laravel DB fournissent les méthodes et la syntaxe correspondantes. Dans le développement réel, nous pouvons utiliser des générateurs de requêtes, des transactions et des connexions en combinaison selon les besoins pour réaliser des opérations de données flexibles et efficaces.

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