Problème avec une requête SQL

zgaw_1987 Messages postés 19 Statut Membre -  
Reivax962 Messages postés 3742 Statut Membre -
Bonjour,

Je suis actuellement confronté à un problème avec une requête SQL. Sur une page, un utilisateur à plusieurs champs de recherches:
-type -adresse -prix....
Ces champs ne sont pas obligatoires ! Donc par exemple un utilisateur saisi juste le "type" et clique sur recherche.
On arrive sur une autre page de résultat et là, j'aimerais faire le teste seulement sur le "type".
Merci

3 réponses

Reivax962 Messages postés 3742 Statut Membre 1 011
 
Bonjour,

Je te suggères de construire ta requête en concaténant des chaînes de caractères, en fonction des champs remplis.

Par exemple, pour type, adresse et prix :
function getCritere($champ, $valeur, $operateurBooleen, $premier)
{
    resultat = '';
    if ($valeur != '')
    {
        if (!$premier)
            $resultat = " $operateurBooleen ";
        $resultat .= " $champ = '$valeur'";
    }
    return $resultat;
}

$prix = (isset($_POST['prix'])) ? $_POST['prix'] : '';
$type = (isset($_POST['type'])) ? $_POST['type'] : '';
$adresse = (isset($_POST['adresse'])) ? $_POST['adresse'] : '';

$clauseWhere = getCritere('prix', $prix, 'AND', true);
$clauseWhere .= getCritere('type', $type, 'AND', ($clauseWhere == ''));
$clauseWhere .= getCritere('adresse', $adresse, 'AND', ($clauseWhere == ''));

if ($clauseWhere != '') $clauseWhere = ' WHERE'.$clauseWhere;

$sqlQuery = "SELECT * FROM table $clauseWhere";
...


Voilà :)

Xavier
1
amie_ccm
 
salam,
suivant votre cas, vous aurrez besoin de plusieurs requêtes SQL; chaque cas avec sa requête (en testant la disonibilité d'info dans les champs);
@+
0
amie_ccm
 
salam,
suivant votre cas, vous aurrez besoin de plusieurs requêtes SQL; mais bien sûr une (1) seulement sera executée; en testant la disponibilité d'info dans les champs à saisir, chaque cas correspond à une requête bien precise.
@+
0
zgaw_1987 Messages postés 19 Statut Membre
 
Bonjour;
merci pour votre réponse. je fait le recherche selon 5 critère et cela veut dire qu'il me faut 32 requette sql???
est ce que c'est logique?
merci
0