Fonction SELECT de MySQL, les champs
Résolu
Halifax45
Messages postés
5
Date d'inscription
Statut
Membre
Dernière intervention
-
le père -
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
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:
- Fonction SELECT de MySQL, les champs
- Fonction si et - Guide
- Mysql community server - Télécharger - Bases de données
- Fonction miroir - Guide
- Please select boot device - Forum Matériel & Système
- Fonction moyenne excel - Guide
8 réponses
Salut,
Voici peut-être une solution :
Voici peut-être une solution :
$variable = 'nom'; $sel = 'SELECT'.$variable.'FROM ma table'; $req = mysql_query($sel);
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
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
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
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);
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);
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
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...
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...
Normal tu as mis des ' en trop dans ta $sel
il faut:
il faut:
$sel = "SELECT ".$mot1." FROM final"; ou $sel = "SELECT $mot1 FROM final";
Sinon le code SQL généré seradu genre
SELECTchampFROM matable