Afficher le nom des colonnes d'une table via une requete SQL
Résolu
Ndediop
Messages postés
101
Date d'inscription
Statut
Membre
Dernière intervention
-
Ndediop Messages postés 101 Date d'inscription Statut Membre Dernière intervention -
Ndediop Messages postés 101 Date d'inscription Statut Membre Dernière intervention -
A voir également:
- Requete sql pour afficher les champs d'une table
- Table ascii - Guide
- Table des matières word - Guide
- Afficher appdata - Guide
- Word mettre à jour tous les champs ✓ - Forum Word
- Afficher toutes les lignes masquées excel ✓ - Forum Excel
4 réponses
Bonjour,
Même remarque que d'habitude ....
Montre ce que tu as essayé et qui ne "marche pas" ... et nous verrons pour te le corriger;
Même remarque que d'habitude ....
Montre ce que tu as essayé et qui ne "marche pas" ... et nous verrons pour te le corriger;
Ndediop
Messages postés
101
Date d'inscription
Statut
Membre
Dernière intervention
Voila:
Bonjour,
Pour ce genre de requête qui touche au fonctionnement propre du SGBD, il est indispensable de savoir lequel tu utilises. Chaque SGBD aura un comportement différent.
Xavier
Pour ce genre de requête qui touche au fonctionnement propre du SGBD, il est indispensable de savoir lequel tu utilises. Chaque SGBD aura un comportement différent.
Xavier
Bonjour,
J'ai mis le bd_name.table_name afin de voir ce que ça donne mais ça reviens au même ya pas de changement du coups voila le code avec la requête:
J'ai mis le bd_name.table_name afin de voir ce que ça donne mais ça reviens au même ya pas de changement du coups voila le code avec la requête:
<div id="champsoper"> <select name="champsoper" id="champsoper"> <option value="">** Sélectionner... **</option> $requete="SHOW COLUMNS FROM bde.operations"; $resultats= $bdd_connection->query($requete); while($ligne = $resultats->fetch()){ echo'<option value=""></option>'; } echo'</select> </div></div>
Bonjour
La requête n'est pas mauvaise, mais il y a d'autres problèmes :
- il manque la balise <?php avant le $requete - je suppose que le manque d'apostrophe et de ?> à la fin de la partie PHP viennent d'un mauvais découpage.
- il y a deux éléments avec le même id (même si ça n'empêche pas la requête de de marcher)
- dans la dernière version que tu montres, il n'y a plus de $ligne[0] dans les <option>, c'est bien dommage
- enfin, si comme moi tu as choisi l'option FETCH_ASSOC dans la connexion à ta base de données, le $ligne[0] ne va pas marcher, il va falloir utiliser $ligne['Field']
Ceci corrigé, ça marche.
La requête n'est pas mauvaise, mais il y a d'autres problèmes :
- il manque la balise <?php avant le $requete - je suppose que le manque d'apostrophe et de ?> à la fin de la partie PHP viennent d'un mauvais découpage.
- il y a deux éléments avec le même id (même si ça n'empêche pas la requête de de marcher)
- dans la dernière version que tu montres, il n'y a plus de $ligne[0] dans les <option>, c'est bien dommage
- enfin, si comme moi tu as choisi l'option FETCH_ASSOC dans la connexion à ta base de données, le $ligne[0] ne va pas marcher, il va falloir utiliser $ligne['Field']
Ceci corrigé, ça marche.
- c'est juste une portion de mon code
C'est très bien de simplifier le code pour le montrer ici, mais comment on distingue les erreurs qu'il y avait vraiment dans ton code de celles que tu rajoutes en le simplifiant ?
- j'ai mis des balises php pour la connexion à la base de données
C'est très bien aussi, mais celle dont je te parle ne concerne pas la connexion à la base de données.
C'est très bien de simplifier le code pour le montrer ici, mais comment on distingue les erreurs qu'il y avait vraiment dans ton code de celles que tu rajoutes en le simplifiant ?
- j'ai mis des balises php pour la connexion à la base de données
C'est très bien aussi, mais celle dont je te parle ne concerne pas la connexion à la base de données.
C'était juste pour dire qu'il faut bien qu'on signale toutes les erreurs, on ne peut pas deviner celles qu'il y avait vraiment au départ et celles que tu as ajoutées.
Sinon, pour le $ligne[0], utilises-tu des options particulières lors de la connexion ? Si ce n'est pas le cas, le $ligne['Field'] ne donnera rien de plus.
Sinon, pour le $ligne[0], utilises-tu des options particulières lors de la connexion ? Si ce n'est pas le cas, le $ligne['Field'] ne donnera rien de plus.
voila le code pour une rangée de ma table car elles sont toutes identiques pour que vous puissiez voir ce que je fais et me donnez un coups de pouce.
<!DOCTYPE html> <html> <body> <?php session_start(); ?> <?php require('../../bdconnect.php'); ?> </td></tr></table></td></tr></table></td></tr></table></td></tr></table></div></td> </tr> <tr> <td><div id="champs" objImgPliage="ctrl_59423ad0b488b0-47625125_549" objBlocPliage="ctrl_59423ad0b488b0-47625125_550"><table width="100%" border="0" cellpadding="0" cellspacing="0" class="styleCadreBloc1"> <tr><td><table width="100%" border="0" cellspacing="0" cellpadding="0"> <tr style="background-color: #FF8C00;"> <td class="styleTitreBloc2">Champs du tableau</td></tr></table></td></tr><tr id="ctrl_59423ad0b488b0-47625125_550" style="background-color: #FFFFFF;"><td class="styleCorpsBloc"><table width="100%" border="0" cellspacing="0" cellpadding="0" onDblClick=""><tr><td><table width="100%" border="0" cellspacing="0" cellpadding="0"><tr><td width="100%" valign="top"><table width="100%" border="0" cellspacing="3" cellpadding="0"><tr><td class="styleFicheIntitule"><div>Champs 1 :</div></td><td nowrap valign="top"> <!-- CTRL "Liste Table" : lstGroupeChamps[1] --> <div id="lstGroupeChamps[1]" ident="_objListeItem" nomObjet="lstGroupeChamps[1]" class="styleListeExt" style="width: 120px" classItem="styleItemListe" verrou="0" nomDivErr="ctrl_59423ad0b488b0-47625125_144" nomCtrlValeur="ctrl_59423ad0b488b0-47625125_145" valeurNull="-1" texteNull="..."> <div> <div> <select id="tableoper" name="tableoper" class="form-control"> <option value="">...</option> <option value="01-operations">operations</option> <option value="02-operations">operations</option> <option value="03-operations">operations</option> <option value="04-operations">operations</option> <option value="05-operations">operations</option> <option value="06-operations">operations</option> <option value="07-operations">operations</option> <option value="08-operations">operations</option> </select> </div></div> </td></tr></table></td> </tr> </table></td> </tr> </table> <script language="javascript" type="text/javascript">startJava();</script> </body> </html>
Bonjour,
Donc voici :
1 - Active la gestion des erreurs dans la connexion à ta bdd
en pdo : comme ceci https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
2 - Active l'affichage des erreurs PHP en ajoutant au début de tes fichiers php les lignes suivantes
3 - En général .. on place le maximum de code php AVANT le code html !
4 - Voici un exemple qui fonctionne parfaitement :
Donc voici :
1 - Active la gestion des erreurs dans la connexion à ta bdd
en pdo : comme ceci https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
<?php try{ $bdd = new PDO ('mysql:host=localhost;dbname=bde;charset=utf8', 'root', ''); // Activation des erreurs PDO $bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // mode de fetch par défaut : FETCH_ASSOC / FETCH_OBJ / FETCH_BOTH $bdd->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); } catch(PDOException $e) { die('Erreur : ' . $e->getMessage()); } ?>
2 - Active l'affichage des erreurs PHP en ajoutant au début de tes fichiers php les lignes suivantes
error_reporting(E_ALL); ini_set('display-errors','on');
3 - En général .. on place le maximum de code php AVANT le code html !
4 - Voici un exemple qui fonctionne parfaitement :
<?php //-------------------------------------// // Affichage des erreurs PHP //-------------------------------------// error_reporting(E_ALL); ini_set('display-errors','on'); //-------------------------------------// //démarrage session //-------------------------------------// session_start(); //-------------------------------------// //connexion à la bdd //-------------------------------------// require_once 'bddconnect.php'; //-------------------------------------// //liste des champs de la table //-------------------------------------// $sql = "SHOW COLUMNS FROM bde.operations"; //Execution de la requete try{ $requete = $bdd -> prepare($sql) ; $requete->execute(); $liste_champs = $requete->fetchAll(); //on stocke le resultat dans un array }catch(Exception $e){ // en cas d'erreur : echo " Erreur ! ".$e->getMessage(); echo " Les datas : " ; print_r($datas); } ?> <!DOCTYPE html> <html> <body> <div id="champsoper"> <select name="champsoper" id="champsoper"> <option value="">** Sélectionnez.**</option> <?php //-------------------------------------// // Boucle sur l'array si pas vide //-------------------------------------// if(!empty($liste_champs)){ foreach($liste_champs as $champ){ $field = $champ['Field']; $Type = $champ['Type']; echo "<option value='$field'>$field ($Type) </option>"; } } ?> </select> </div> </body> </html>
Bonjour Jordane,
Je viens de voir votre message merci pour la réponse je ferai ce que vous m'avez dit et je vous reviendrai, mais une autre question, j'ai 28 lignes et chaque ligne je dois faire la même chose, donc avant chaque option des opérations je dois mettre d’abords le code PHP? Car je les ai mis sous forme de tableau.
Merci d'avance!
Cordialement,
ndediop
Je viens de voir votre message merci pour la réponse je ferai ce que vous m'avez dit et je vous reviendrai, mais une autre question, j'ai 28 lignes et chaque ligne je dois faire la même chose, donc avant chaque option des opérations je dois mettre d’abords le code PHP? Car je les ai mis sous forme de tableau.
Merci d'avance!
Cordialement,
ndediop