Fonction SELECT de MySQL, les champs

Résolu
Halifax45 Messages postés 5 Date d'inscription   Statut Membre Dernière intervention   -  
 le père -
Bonjour à tous,

La fonction SELECT de MySQL peut communément être suivie du nom d'un ou plusieurs champs, par exemple "SELECT nom,adresse, etc" ou encore de l'astérisque pour une sélection de tous les champs "SELECT * etc". Jusque là tout va bien. Seulement moi, j'aimerais faire le choix d'un champs en fonction du contenu d'une variable PHP.

Par exemple $var contient 'nom' et j'aimerais faire une recherche du genre "SELECT $var etc". Sauf que cela ne fonctionne pas. J'ai essayé avec apostrophe '$var', guillements "$var", sans, un peu de tout et jusqu'à présent, je n'ai trouvé aucun exemple qui éclaire ma lanterne. D'où ce post.

En somme, dans MySQL, peut-on remplacer le nom d'un champs par une variable qui la contient, juste après la fonction SELECT ?.

Un grand merci pour votre aide.

Halifax
A voir également:

8 réponses

BiiGiX Messages postés 16 Date d'inscription   Statut Membre Dernière intervention   2
 
Salut,

Voici peut-être une solution :

$variable = 'nom';

$sel = 'SELECT'.$variable.'FROM ma table';
$req = mysql_query($sel);
0
Dr Zoidberg Messages postés 529 Date d'inscription   Statut Membre Dernière intervention   100
 
Juste une petite corrrection, tu as juste oublié les espaces dans la chaine :
$sel = 'SELECT '.$variable.' FROM matable';


Sinon le code SQL généré seradu genre
SELECTchampFROM matable
0
Halifax45 Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
Et bien, j'avoue que vu mon niveau préhistorique en PHP et MySQL, je n'en sais rien. Mais je vais essayer et je reviens après le week end pour ce que ça dit, je n'aurai malheureusement pas trop le temps de tester d'ici là. En tout cas, merci pour la réponse rapide BiiGiX
0
Halifax45 Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
Bonsoir à tous,

Merci pour vos interventions. Cela dit, apparemment SQL ne veut pas de cette solution pourtant sympa. La syntaxe par exemple "SELECT nom FROM final" en toutes lettres fonctionne évidement très bien mais le principe de remplacer l'ensemble (y compris les trémas) par une variable ne plaît pas. Si je fais un ECHO $sel; selon l'exemple donné par BiiGix, j'ai bien la même chose qui s'affiche qu'en toutes lettres mais SQL n'est pas d'accord.

Si donc quelqu'un a une idée...

Merci encore
0
le père
 
Bonjour

Si, si, SQL devrait être d'accord, il doit y avoir autre chose qui cloche. Peux-tu montrer ton code ?
SQL ne distingue pas une requête avec variables PHP d'une requête sans variables PHP parce que SQL ne voit JAMAIS les variables PHP, c'est le PHP qui les remplace par leurs valeurs avant de passer la requête à mySQL.
mySQl ne peut matériellement pas faire la différence entre :
mysql_query("SELECT nom FROM final");
et
$variable = "nom";
mysql_query("SELECT ".$variable." FROM final");
ou
$variable = "nom";
$req= "SELECT ".$variable." FROM final";
mysql_query($req);
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Halifax45 Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
Bonsoir le père

Ah? Heureux de le savoir, cela me rassure.

Bon, j'ai pour l'instant une petite table de rien, pour test, que j'ai appelée "final" et venant d'un autre code HTML, la variable $mot1 contient par exemple le mot "bouteille"

Voici le bout de code qui fonctionne:

$req = mysql_query("SELECT bouteille FROM final");
?><br /><?php
while ($donnees = mysql_fetch_array($req) )
{
Echo $donnees[$mot1];?><br /><?php
}



et celui qui plante:

$sel = '"SELECT '.$mot1.' FROM final"'; echo $sel;
$req = mysql_query($sel);
?><br /><?php
while ($donnees = mysql_fetch_array($req) )
{
Echo $donnees[$mot1];?><br /><?php
}



Le message d'erreur est le suivant :

Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in D:\aaDivers\db PHP\Test\table.php on line 52

Que dire de plus...
0
Alain_42 Messages postés 5361 Date d'inscription   Statut Membre Dernière intervention   894
 
Normal tu as mis des ' en trop dans ta $sel

il faut:

$sel = "SELECT ".$mot1." FROM final"; 

ou  

$sel = "SELECT $mot1 FROM final";
0
Halifax45 Messages postés 5 Date d'inscription   Statut Membre Dernière intervention  
 
Bonjour Alain_42,

C'est parfait. Tant qu'à faire, la deuxième option est ma préférée, c'est tout propre comme code. Après coup, ça paraît évident mais bon. Problème résolu en tout cas, je vais pouvoir avancer.

Un grand merci, également aux autres membres qui m'ont répondu auparavent

Halifax
0
le père
 
Je viens de comprendre ce que tu entendais par (y compris les trémas) et qui m'avait semblé bizarre ! Ce sont les double quotes que tu appelles des trémas !
0