Maison  >  Article  >  cadre php  >  Comment utiliser les conditions pour filtrer les requêtes liées à thinkphp

Comment utiliser les conditions pour filtrer les requêtes liées à thinkphp

PHPz
PHPzoriginal
2023-04-07 09:30:001342parcourir

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.

  1. 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.

  1. 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.

  1. 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.

  1. 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!

Déclaration:
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