Lors du développement avec thinkphp, vous rencontrez souvent des situations dans lesquelles vous devez utiliser des requêtes associées. Lors de l'exécution de requêtes associées, les conditions sont un point auquel nous devons souvent prêter attention.
Cet article expliquera comment utiliser les conditions pour filtrer lors de l'exécution de requêtes associées dans thinkphp.
- Définir l'association dans le modèle
Lors de l'exécution d'une requête associée, vous devez d'abord définir l'association dans le modèle. Nous prenons ici comme exemple une relation un-à-un. Tout d'abord, définissez un modèle User, qui contient une association hasOne :
class User extends Model { protected $table = 'users'; public function profile() { return $this->hasOne('Profile'); } }
Dans le code ci-dessus, nous définissons une association hasOne nommée profile, qui est associée à un modèle nommé Profile. Dans le modèle Profile, vous devez définir l'association AppartientTo :
class Profile extends Model { protected $table = 'profiles'; public function user() { return $this->belongsTo('User'); } }
Dans le code ci-dessus, nous définissons une association AppartientTo nommée user, qui est associée à un modèle nommé User.
- Effectuer une requête associée
Après avoir défini la relation, nous pouvons effectuer des requêtes associées dans le contrôleur. L'instruction de requête est la suivante :
$users = User::with(['profile' => function($query){ $query->where('age', '>=', 18); }])->select();
Dans le code ci-dessus, nous avons utilisé la méthode with pour effectuer une requête associée. Parmi eux, le premier paramètre transmet l'association que nous voulons interroger, et le deuxième paramètre est une fonction de rappel utilisée pour imposer des restrictions conditionnelles supplémentaires sur cette requête.
Dans le code ci-dessus, nous avons utilisé la méthode Where pour filtrer l'attribut age du modèle de profil et interroger uniquement les enregistrements dont l'âge est supérieur ou égal à 18.
- Conditions de fonctionnement chaînées
En plus de transmettre la fonction de rappel dans la méthode with pour limiter les conditions de requête, vous pouvez également effectuer des conditions de fonctionnement chaînées lors de l'exécution de requêtes associées. Par exemple, le code suivant implémente une requête pour les utilisateurs dont l'âge est supérieur ou égal à 18 ans dans la table user, et pour les enregistrements dont l'adresse n'est pas vide dans leurs enregistrements de profil :
$users = User::where('age', '>=', 18) ->with(['profile' => function($query){ $query->where('address', '', ''); }]) ->select();
Dans le code ci-dessus, on interroge d'abord le Modèle utilisateur via la méthode Where Les conditions de requête sont restreintes. Ensuite, nous avons utilisé la fonction de rappel dans la méthode with pour restreindre les conditions de requête du modèle de profil.
- Résumé
Lors de l'exécution de requêtes associées dans thinkphp, nous pouvons utiliser la méthode with pour effectuer des requêtes associées, et restreindre et filtrer davantage les résultats de la requête en transmettant des fonctions de rappel ou des conditions de fonctionnement chaînées.
Bien sûr, lors de l'exécution de requêtes associées, nous devons également prêter attention à d'autres détails, tels que la définition des relations d'association, l'écriture des instructions de requête, etc. Dans le processus de développement actuel, nous devons effectuer des opérations flexibles en fonction de circonstances spécifiques.
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!

L'article traite du cadre de test intégré de ThinkPhP, mettant en évidence ses principales fonctionnalités telles que les tests d'unité et d'intégration, et comment il améliore la fiabilité des applications grâce à la détection précoce des bogues et à une meilleure qualité de code.

L'article discute de l'utilisation de ThinkPHP pour les flux de données boursières en temps réel, en se concentrant sur la configuration, la précision des données, l'optimisation et les mesures de sécurité.

L'article traite des considérations clés pour l'utilisation de ThinkPHP dans des architectures sans serveur, en se concentrant sur l'optimisation des performances, la conception sans état et la sécurité. Il met en évidence des avantages tels que la rentabilité et l'évolutivité, mais relève également des défis

L'article discute de la mise en œuvre de la découverte de services et de l'équilibrage des charges dans les microservices ThinkPHP, en se concentrant sur la configuration, les meilleures pratiques, les méthodes d'intégration et les outils recommandés. [159 caractères]

Le conteneur IOC de ThinkPhp propose des fonctionnalités avancées comme le chargement paresseux, la liaison contextuelle et l'injection de méthode pour une gestion efficace des dépendances dans les applications PHP. COMMANDE CHARACTER: 159

L'article discute de l'utilisation de ThinkPHP pour créer des outils de collaboration en temps réel, en se concentrant sur la configuration, l'intégration WebSocket et les meilleures pratiques de sécurité.

ThinkPHP profite aux applications SaaS avec sa conception légère, son architecture MVC et sa extensibilité. Il améliore l'évolutivité, accélère le développement et améliore la sécurité grâce à diverses fonctionnalités.

L'article décrit la création d'un système de file d'attente de tâches distribué à l'aide de ThinkPhp et RabbitMQ, en se concentrant sur l'installation, la configuration, la gestion des tâches et l'évolutivité. Les problèmes clés incluent assurer la haute disponibilité, éviter les pièges communs comme Imprope


Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Dreamweaver Mac
Outils de développement Web visuel

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft

Version crackée d'EditPlus en chinois
Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code