Fonction SELECT de MySQL, les champs

Résolu/Fermé
Halifax45 Messages postés 5 Date d'inscription jeudi 14 mai 2009 Statut Membre Dernière intervention 20 mai 2009 - 14 mai 2009 à 16:49
 le père - 20 mai 2009 à 15:01
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 jeudi 19 février 2009 Statut Membre Dernière intervention 13 août 2010 2
14 mai 2009 à 17:02
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 jeudi 28 juin 2007 Statut Membre Dernière intervention 12 juin 2015 100
14 mai 2009 à 22:45
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 jeudi 14 mai 2009 Statut Membre Dernière intervention 20 mai 2009
14 mai 2009 à 22:40
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 jeudi 14 mai 2009 Statut Membre Dernière intervention 20 mai 2009
18 mai 2009 à 22:27
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
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 jeudi 14 mai 2009 Statut Membre Dernière intervention 20 mai 2009
19 mai 2009 à 22:06
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 dimanche 3 février 2008 Statut Membre Dernière intervention 13 février 2017 894
19 mai 2009 à 22:54
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 jeudi 14 mai 2009 Statut Membre Dernière intervention 20 mai 2009
20 mai 2009 à 14:46
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
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