Précédent   Forum des professionnels en informatique > PHP > PHP & SGBD
PHP & SGBD Forum d'entraide sur les SGBD avec PHP. Avant de poster : FAQ BDD, toutes les FAQ PHP, cours BDD et sources BDD
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 26/09/2007, 21h39   #1
Nouveau Membre du Club
 
Inscription : juin 2007
Messages : 57
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 57
Points : 27
Points : 27
Par défaut [SQL] Génération de requête

Bonjour,

Voici mon problème, j'ai un formulaire de recherche comportant 15 champs. L'utilisateur, peut sélectionner un nombre aléatoire de champs. Or vu le nombre de requete possible, je souhaiterais effectuer une seuls requete et non une combinaison de requete alors s'il existe des champs vide, comment faire pour les ignorer, et générer ma requete. Merci de votre aide.
gpanpan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/09/2007, 22h43   #2
Membre Expert
 
Inscription : octobre 2002
Messages : 1 141
Détails du profil
Informations personnelles :
Âge : 32
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : octobre 2002
Messages : 1 141
Points : 1 204
Points : 1 204
Envoyer un message via MSN à Raideman
Tu peux tester si le champ a été saisi avec :
Code :
1
2
 
if((!isset($tonchamp))&&(!empty($ton_champ))
Ensuite si c'est saisi, tu rajouter une condition adéquate dans la clause where de ta requete SQL.
Raideman est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/09/2007, 08h54   #3
Nouveau Membre du Club
 
Inscription : juin 2007
Messages : 57
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 57
Points : 27
Points : 27
Ok pour le test, mais je nai besoin dans mon cas que de !empty pour contrôler si il sont à 0 ou non :
if (!empty($ch1)||($ch2)||($ch3))

Mais le problème c'est comment générer ma requete, vue le nombre de possibilité (15 puissance 15), je ne vois pas comment faire, pour mettre dans ma requete la condition WHERE avec uniquement les champs qui ne son pas 0.

exemple si $ch2=0 je veux générer une requete du type :

SELECT * FROM matable WHERE (ch1=$cha1 OR ch3=$cha3 ) AND (ch1=$cha1 AND ch3=$cha3)

ou si $ch1=0

SELECT * FROM matable WHERE (ch2=$cha2 OR ch3=$cha3 ) AND (ch2=$cha2 AND ch3=$cha3)
gpanpan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/09/2007, 09h15   #4
Membre Expert
 
Inscription : janvier 2005
Messages : 2 288
Détails du profil
Informations forums :
Inscription : janvier 2005
Messages : 2 288
Points : 2 287
Points : 2 287
je sais pas si c'est une erreur dans ton exemple mais
(ch2=$cha2 OR ch3=$cha3 ) AND (ch2=$cha2 AND ch3=$cha3)
c'est la meme chose que
(ch2=$cha2 AND ch3=$cha3)

Le premier OR ne sert a rien puisque tout le résultat dépend du deuxieme AND
koopajah est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/09/2007, 09h38   #5
Membre Expert
 
Inscription : octobre 2002
Messages : 1 141
Détails du profil
Informations personnelles :
Âge : 32
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : octobre 2002
Messages : 1 141
Points : 1 204
Points : 1 204
Envoyer un message via MSN à Raideman
Bien, j'ai du mal m'exprimer, tu peux tres bein faire le code suivant:

Code :
1
2
3
4
5
6
7
8
9
 
$requete="SELECT * FROM matable WHERE 1=1  ";
if (!empty($ch1)){
$requete.=" AND ch1='".$ch1."'";
}
if (!empty($ch2)){
$requete.=" AND ch2='".$ch2."'";
}
etc...
Raideman est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/09/2007, 11h54   #6
Nouveau Membre du Club
 
Inscription : juin 2007
Messages : 57
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 57
Points : 27
Points : 27
Effectivement le AND est une erreur, c'est un OR
Désolé.

Merci Raideman pour les précisions je vais tester dès que possible et je vous tiens informé de la suite.

Merci à vous 2 de vous intéressez à mon problème.
gpanpan est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/09/2007, 14h32   #7
Nouveau Membre du Club
 
Inscription : juin 2007
Messages : 57
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 57
Points : 27
Points : 27
Super ça fonctionne impec !

voila un bout de mon code pour générer la requete :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
 
$requete="SELECT * FROM Interprod WHERE 1=1 AND (";
$Operateur = "";
//   ---------------------	Génération de la première partie du WHERE de la requete  	---------------------
if (!empty($EtatFiche)){
$requete.=" EtatFich='".$SelectEtatFiche."'";
$Operateur = " OR ";
}
if (!empty($Cellule)){
$requete.=$Operateur."Cellule='".$SelectCellule."'";
$Operateur = " OR ";
}
if (!empty($Intervenant)){
$requete.=$Operateur."IDintervenant='".$IDintervenant."'";
$Operateur = " OR ";
}
if (!empty($TypeDemande)){
$requete.=$Operateur."TypeDemande='".$SelectTypeDemande."'";
$Operateur = " OR ";
}
if (!empty($Server)){
$requete.=$Operateur."IDserveur='".$IDserveur."'";
$Operateur = " OR ";
}
if (!empty($App)){
$requete.=$Operateur."IDserveur='".$IDapplication."'";
$Operateur = " OR ";
}
if (!empty($Res)){
$requete.=$Operateur."IDreseau='".$IDreseau."'";
$Operateur = " OR ";
}
if (!empty($DateCreaFich)){
$requete.=$Operateur."DateCreaFich='".$SearchDateCreaFich."'";
$Operateur = " OR ";
}
if (!empty($DateModifFich)){
$requete.=$Operateur."DateModifFich='".$SearchDateModifFich."'";
$Operateur = " OR ";
}
if (!empty($DateClotureFich)){
$requete.=$Operateur."DateClotureFich='".$SearchDateClotureFich."'";
$Operateur = " OR ";
}
if (!empty($Redac)){
$requete.=$Operateur."IDredacteur='".$IDredacteur."'";
$Operateur = " OR ";
}
if (!empty($Dem)){
$requete.=$Operateur."IDdemandeur='".$IDdemandeur."'";
$Operateur = " OR ";
}
if (!empty($FinalUse)){
$requete.=$Operateur."IDfinaluser='".$IDfinaluser."'";
$Operateur = " OR ";
}
if (!empty($NumFiche)){
$requete.=$Operateur."NumInter='".$SearchNumFiche."'";
$Operateur = " OR ";
}
 
 
//  ---------------------	Génération de la transition entre les 2 parties du WHERE de la requete 	 ---------------------
$requete.= ") OR (";
 
$Operateur = "";
//   ---------------------	Génération de la deuxième partie du WHERE de la requete 	 ---------------------
if (!empty($EtatFiche)){
$requete.=" EtatFich='".$SelectEtatFiche."'";
$Operateur = " AND ";
}
if (!empty($Cellule)){
$requete.=$Operateur."Cellule='".$SelectCellule."'";
$Operateur = " AND ";
}
if (!empty($Intervenant)){
$requete.=$Operateur."IDintervenant='".$IDintervenant."'";
$Operateur = " AND ";
}
if (!empty($TypeDemande)){
$requete.=$Operateur."TypeDemande='".$SelectTypeDemande."'";
$Operateur = " AND ";
}
if (!empty($Server)){
$requete.=$Operateur."IDserveur='".$IDserveur."'";
$Operateur = " AND ";
}
if (!empty($App)){
$requete.=$Operateur."IDserveur='".$IDapplication."'";
$Operateur = " AND ";
}
if (!empty($Res)){
$requete.=$Operateur."IDreseau='".$IDreseau."'";
$Operateur = " AND ";
}
if (!empty($DateCreaFich)){
$requete.=$Operateur."DateCreaFich='".$SelectDateCreaFich."'";
$Operateur = " AND ";
}
if (!empty($DateModifFich)){
$requete.=$Operateur."DateModifFich='".$SelectDateModifFich."'";
$Operateur = " AND ";
}
if (!empty($DateClotureFich)){
$requete.=$Operateur."DateClotureFich='".$SelectDateClotureFich."'";
$Operateur = " AND ";
}
if (!empty($Redac)){
$requete.=$Operateur."IDredacteur='".$IDredacteur."'";
$Operateur = " AND ";
}
if (!empty($Dem)){
$requete.=$Operateur."IDdemandeur='".$IDdemandeur."'";
$Operateur = " AND ";
}
if (!empty($FinalUse)){
$requete.=$Operateur."IDfinaluser='".$IDfinaluser."'";
$Operateur = " AND ";
}
if (!empty($NumFiche)){
$requete.=$Operateur."NumInter='".$SearchNumFich."'";
$Operateur = " AND ";
}
 
 
//  ---------------------	Génération de la terminaison de la requete 	 ---------------------
$requete.= ")";
Maintenant il ne me reste plus qu'a ajouter la gestion de du cas particulier où tous les champs sont vides, mais pas de problème pour ça.

Encore merci pour vos conseils.
gpanpan est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h55.


 
 
 
 
Partenaires

Hébergement Web