Maison cadre php Laravel Explication détaillée des instructions de requête dans thinkphp

Explication détaillée des instructions de requête dans thinkphp

Apr 21, 2023 am 10:10 AM

ThinkPHP est un framework d'application Web open source basé sur PHP. Il fournit de nombreux outils et solutions pour un développement pratique, y compris la construction et l'exécution d'instructions de requête. Cet article présentera la fonction d'instruction de requête dans ThinkPHP, y compris le générateur de requêtes et le modèle de données, pour aider les développeurs à effectuer plus efficacement les opérations de base de données.

1. Query Builder

Le générateur de requêtes de ThinkPHP est un ensemble de générateurs d'instructions SQL orientés objet permettant de créer rapidement des instructions SQL complexes. Dans le générateur de requêtes, vous pouvez créer des instructions SQL de types SELECT, UPDATE, INSERT et DELETE à l'aide de plusieurs méthodes.

  1. Instruction de requête SELECT

Utilisez l'instruction de requête SELECT pour obtenir des données dans la base de données. Vous pouvez utiliser la méthode select() du générateur de requêtes pour créer une instruction de requête SELECT :

// 查询所有用户数据
Db::name('user')->select();

// 查询 id 为 1 的用户数据
Db::name('user')->where('id', 1)->find();

// 查询年龄大于 18 岁的用户数据
Db::name('user')->where('age', '>', 18)->select();
Copier après la connexion

Dans le code ci-dessus, Db::name('user') représente la table de données à interroger. La méthode select() indique l'interrogation de toutes les données ; la méthode find() indique l'interrogation d'un seul enregistrement.

  1. Instruction de requête UPDATE

Utilisez l'instruction de requête UPDATE pour mettre à jour les données dans la base de données. Vous pouvez utiliser la méthode update() du générateur de requêtes pour créer une instruction de requête UPDATE :

// 更新 id 为 1 的用户数据
Db::name('user')->where('id', 1)->update(['name' => 'Tom']);

// 将所有用户的角色都更新为 2
Db::name('user')->update(['role_id' => 2]);
Copier après la connexion

Dans la méthode update(), le premier paramètre représente la condition de l'enregistrement à mettre à jour et le deuxième paramètre est les données mises à jour. contenu.

  1. Instruction de requête INSERT

Utilisez l'instruction de requête INSERT pour insérer de nouvelles données dans la base de données. Vous pouvez utiliser la méthode insert() du générateur de requêtes pour créer une instruction de requête INSERT :

// 向 user 表中插入一条新数据
Db::name('user')->insert(['name' => 'Jack', 'age' => 20, 'role_id' => 1]);
Copier après la connexion

Dans la méthode insert(), le paramètre est le nouveau contenu de données à insérer.

  1. Instruction de requête DELETE

Utilisez l'instruction de requête DELETE pour supprimer des données dans la base de données. Vous pouvez utiliser la méthode delete() du générateur de requêtes pour créer une instruction de requête DELETE :

// 删除 id 为 1 的数据
Db::name('user')->where('id', 1)->delete();

// 删除所有角色为 3 的用户数据
Db::name('user')->where('role_id', 3)->delete();
Copier après la connexion

Dans la méthode delete(), le paramètre est la condition de l'enregistrement à supprimer.

2. Modèle de données

En plus du générateur de requêtes, ThinkPHP fournit également un ensemble de méthodes de fonctionnement de base de données basées sur le modèle de données, qui peuvent mapper la table de données dans une classe et traiter automatiquement la base de données en fonction des changements dans les attributs de la classe. . CRUD enregistré.

  1. Définir le modèle de données

Vous pouvez définir une classe de modèle de données en utilisant le code suivant :

namespace app\common\model;

use think\Model;

class User extends Model
{
    // 数据表名
    protected $table = 'user';

    // 自动写入时间戳
    protected $autoWriteTimestamp = true;

    // 模型关联:用户角色
    public function role()
    {
        return $this->belongsTo(Role::class, 'role_id');
    }
}
Copier après la connexion

Dans l'exemple ci-dessus, nous avons défini une classe de modèle de données utilisateur en héritant de la classe thinkModel. L'attribut $table indique le nom de la table de données à mapper et l'attribut $autoWriteTimestamp indique s'il faut écrire automatiquement les horodatages.

  1. Requête de données

Nous pouvons utiliser find(), select(),where() et d'autres méthodes du modèle de données pour interroger la base de données :

// 查询 id 为 1 的用户数据
$user = User::find(1);

// 查询用户表中所有数据
$users = User::select();

// 查询年龄大于 18 岁的用户数据
$users = User::where('age', '>', 18)->select();
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé la méthode statique du classe de modèle de données pour effectuer une requête de base de données.

  1. Mettre à jour et insérer des données

Nous pouvons utiliser la méthode save() du modèle de données pour mettre à jour et insérer des données :

// 更新 id 为 1 的用户数据
$user = User::find(1);
$user->name = 'Tom';
$user->save();

// 向 user 表中插入一条新数据
$user = new User;
$user->name = 'Jack';
$user->age = 20;
$user->role_id = 1;
$user->save();
Copier après la connexion

Dans l'exemple ci-dessus, nous utilisons les propriétés de l'objet du modèle de données pour définir les données sur être mis à jour ou inséré, puis appelez la méthode save() pour le soumettre à la base de données.

  1. Supprimer les données

Nous pouvons utiliser la méthode delete() du modèle de données pour supprimer des données :

// 删除 id 为 1 的用户数据
$user = User::find(1);
$user->delete();

// 删除所有角色为 3 的用户数据
User::where('role_id', 3)->delete();
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé la méthode delete() de l'objet du modèle de données pour supprimer l'enregistrement spécifié, ou nous pouvons utiliser static. Utilisez la méthodewhere() de la méthode pour sélectionner l'enregistrement à supprimer, puis appelez la méthode delete() pour le supprimer.

Résumé

Ce qui précède explique comment utiliser ThinkPHP pour construire des instructions de requête. Le générateur de requêtes fournit une variété de méthodes pour construire des instructions SQL telles que SELECT, UPDATE, INSERT et DELETE. Manipuler la base de données. Que ce soit en utilisant le générateur de requêtes ou le modèle de données, nous pouvons rapidement créer des instructions de requête SQL complexes pour faciliter aux développeurs l'exécution d'opérations de base de données.

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
3 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 construire une API RESTful avec des fonctionnalités avancées à Laravel? Comment construire une API RESTful avec des fonctionnalités avancées à Laravel? Mar 11, 2025 pm 04:13 PM

Cet article guide la construction d'API Robust Laravel Restful. Il couvre la configuration du projet, la gestion des ressources, les interactions de base de données, la sérialisation, l'authentification, l'autorisation, les tests et les meilleures pratiques de sécurité cruciale. Aborder l'évolutivité chall

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 mettre en œuvre l'authentification et l'autorisation OAuth2 dans Laravel? Comment mettre en œuvre l'authentification et l'autorisation OAuth2 dans Laravel? Mar 12, 2025 pm 05:56 PM

Cet article détaille la mise en œuvre d'authentification et d'autorisation OAuth 2.0 dans Laravel. Il couvre à l'aide de packages comme les solutions de ligue / oauth2-serveur ou spécifiques au fournisseur, mettant l'accent sur la configuration de la base de données, l'enregistrement du client, la configuration du serveur d'autorisation

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.

Quelles sont les meilleures façons de gérer les téléchargements de fichiers et le stockage cloud dans Laravel? Quelles sont les meilleures façons de gérer les téléchargements de fichiers et le stockage cloud dans Laravel? Mar 12, 2025 pm 05:54 PM

Cet article explore des stratégies optimales de téléchargement de fichiers et de stockage cloud dans Laravel. Il examine le stockage local vs fournisseurs de cloud (AWS S3, Google Cloud, Azure, DigitalOcean), mettant l'accent sur la sécurité (validation, désinfection, HTTPS) et Performance Opti

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.

See all articles