Maison  >  Article  >  développement back-end  >  Comment utiliser un tableau comme condition de requête en php

Comment utiliser un tableau comme condition de requête en php

PHPz
PHPzoriginal
2023-04-19 11:37:56754parcourir

Dans le développement PHP, il est souvent nécessaire d'interroger des données en fonction d'un ensemble de conditions. Cet ensemble de conditions est souvent transmis au programme sous la forme d'un tableau et nous devons le convertir en conditions de requête dans une instruction SQL. Cet article explique comment utiliser les tableaux comme conditions de requête pour les requêtes.

1. Contexte

Dans le développement réel, nous devons souvent interroger les données de la base de données en fonction de différentes conditions. Ces conditions peuvent inclure des relations simples telles que égal à, non égal à, supérieur à, inférieur à, etc., ou elles peuvent inclure des relations logiques complexes telles que « ou », « et », « non », etc. Afin de faciliter le traitement de ces conditions, nous les encapsulons généralement dans un tableau, par exemple :

$where = array(
    'id' => 1,
    'name' => 'Tom',
    'age' => array('gt', 18),
    'or' => array(
        'status' => 1,
        'score' => array('egt', 60)
    )
);

Dans le code ci-dessus, le tableau $where représente une condition de requête, qui comprend les cinq conditions d'identifiant, de nom, d'âge, statut et score. Leurs significations sont les suivantes :

  • id=1
  • name='Tom'
  • age>18
  • (status=1 or score>=60)

Nous devons convertir ce tableau en requête dans un Instruction SQL Conditions d'exécution des requêtes de base de données.

2. Implémentation

En PHP, nous pouvons utiliser la concaténation de chaînes pour convertir le tableau en conditions de requête de l'instruction SQL. Il convient de noter que nous devons déterminer le type de chaque élément du tableau et regrouper différentes conditions en fonction de différents types. Ce qui suit est une implémentation simple :

function whereToStr($where) {
    $str = '';
    foreach ($where as $k=>$v) {
        if (is_array($v)) {
            if ($k == 'or') {
                $str .= '(' . whereToStr($v) . ') OR';
            } elseif ($k == 'and') {
                $str .= '(' . whereToStr($v) . ') AND';
            } else {
                $str .= $k . ' ' . $v[0] . ' ' . $v[1] . ' AND ';
            }
        } else {
            $str .= $k . ' = "' . $v . '" AND ';
        }
    }
    return rtrim($str, ' AND');
}

Cette fonction parcourra de manière récursive tous les éléments du tableau et générera des conditions de requête correspondantes en fonction du type de l'élément. Si l'élément est une simple paire clé-valeur, la condition d'égalité correspondante est générée ; si l'élément est un tableau, les opérateurs "ou" et "et" sont générés en fonction du nom de clé du tableau, ou une expression conditionnelle est générée. généré.

Selon l'implémentation ci-dessus, nous pouvons convertir le tableau $where en conditions de requête suivantes :

id = “1” AND name = “Tom” AND age > “18” AND (status = “1” OR score >= “60”)

3. Résumé

L'utilisation de tableaux comme conditions de requête pour les requêtes est une exigence courante dans le développement PHP, et c'est également une exigence plus importante. manière commode. Nous pouvons encapsuler les conditions dans un tableau, puis convertir les conditions de requête par simple concaténation de chaînes. En fait, certains frameworks PHP couramment utilisés intègrent des fonctions d’encapsulation et de conversion de conditions de requête similaires, ce qui peut grandement simplifier l’écriture de code.

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