Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : compter les fils par niveaux dans un arbre ordonnée [ Base de données / MySQL ] (paroleparleet)

samedi 15 novembre 2008 à 19:13:47 | compter les fils par niveaux dans un arbre ordonnée

paroleparleet

Bonsoir à tous,

J'aimerais que vous puissiez m'aider à resoudre un problème que j'ai rencontré dans mon projet.

je dois compter le nombre de fils par niveau dans un arbre ordonné: l'arbre se presente de la façon suivante,  avant de la presentée j'aimerais vous signifier que je me sert d'une base MySql pour traiter mes informations.

mon fichier se présente comme ceci:

table_element (id_element,code_element,nom_element,code_parent_element)

                                       1
                    /                  |            \
                 /                     |                  \
             /                         |                      \
         10                         11                       12
      /    |    \                  /    |     \           /        |     \
100  101 102        110   111  112    120  121  122

------

je vous prie de m'aider j'ai besoin de cela le plutôt possible.

samedi 15 novembre 2008 à 20:53:29 | Re : compter les fils par niveaux dans un arbre ordonnée

nhervagault

Administrateur CodeS-SourceS
Salut

Quel est le resultat attendu ?
Il faut peut etre faire du parcours recursif?

Bon coding

samedi 15 novembre 2008 à 21:24:24 | Re : compter les fils par niveaux dans un arbre ordonnée

paroleparleet

Je vous remercie pour ta réponse.J'ai essayé la recurcivité mais je ne sais comment procéder pour afficher :

 Total : ........    Niveau :.......

Voici mon code qui me sert à afficher le contenu de ma base :


<?php
 #Paramétres de configuration

 $hostname = "localhost";
 $database = "test_arbre";
 $Username = "root";
 $password = "";

 $Dataconnection = mysql_connect($hostname, $Username, $password) or die(mysql_error());

 // paramétre mysql et chargement de la classe bdd.
mysql_select_db($database, $Dataconnection);

?>

<html>
<head>
<title>Document sans nom</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style type="text/css">
<!--
.label {
 font-family: "Trebuchet MS", "Tw Cen MT", "Tw Cen MT Condensed";
 font-weight: bold;
 color: #FFFFFF;
 font-size: small;
}
.label1 {
 font-family: "Trebuchet MS", "Tw Cen MT", "Tw Cen MT Condensed";
 font-weight: bold;
 color: #FF0000;
 font-size: small;
}
.label2 {
 font-family: "Trebuchet MS", "Tw Cen MT", "Tw Cen MT Condensed";
 font-weight: bold;
 color: #000000;
 font-size: small;
}
-->
</style>
</head>
<BODY leftMargin=0 topMargin=0 marginheight="0" marginwidth="0">
<form name="forgotpass" method="post" action="">
  <table width="400" border="0" bgcolor="#FFCC66" align="center" cellspacing="5" cellpadding="5">
       <td width="200" align="right" class="label2">Selectionnez le Pseudo :</td>
       <td width="100">
          <?
              $result=mysql_query("select nom_exemple
                                   from tab_exemple order by id_exemple",$Dataconnection);
              echo"<select name=\"usernam\">";
              while (list($affichage)=mysql_fetch_array($result)){
                echo"<option>$affichage</option>";
              }
              echo"</select>";
          ?>
       </td>
       <td width="100"><input name="afficher" type="submit" value="Afficher >>" style=" BORDER-RIGHT: #999999 1px solid;
            BORDER-TOP: #999999 1px solid;
            FONT-SIZE: 11px;
            BACKGROUND: #336699;
            BORDER-LEFT: #999999 1px solid;
            COLOR: #cc3300;BORDER-BOTTOM: #999999 1px solid;
            FONT-FAMILY: Helvetica;
            TEXT-DECORATION: none">
       </td>
    </tr>

  </table>
</form>
</body>

<?php

     if(isset($_POST['afficher'])){

        $nom = $_POST['usernam'];

        $result_global=mysql_query("select code_exemple
                                    from tab_exemple
                                    where nom_exemple='$nom'"
                                  );
        list($code_depart)=mysql_fetch_array($result_global);
              
        echo"Code Pere : $code_depart<br>";

        affichage_branche($code_depart);

     }

    function affichage_branche($code_depart) {

       $niveau1 =0;

       $nbfils =0;

       $nbfils1 =0;
      
       $num1 =0;

       $result_query = mysql_query("select code_noeud,niveau_noeud
                                    from tab_noeud
                                    where parent_noeud='$code_depart'"
                                  );

       while (list($code,$niveau)=mysql_fetch_array($result_query)) {

         $num = mysql_num_rows($result_query);

         $tab=str_repeat(".",$niveau*4);
      
         echo "<li>".$tab."Code : ".$code." Nbre Fils : ".$num." Niveau :".$niveau;

         affichage_branche($code);

         $num1 = $num;

         $niveau1 = $niveau;

       }

       if($niveau1 == $niveau){}
       else{

           $tab=str_repeat(".",$niveau1*4);

           echo "<br><li>$tab T Nbre Fils : ".$num1." Niveau :".$niveau1;
          
       }

    }

?>


mercredi 19 novembre 2008 à 00:35:49 | Re : compter les fils par niveaux dans un arbre ordonnée

malalam

Administrateur CodeS-SourceS
Hello,

une requête du genre :

SELECT c.code_element, count(*)
FROM codes
INNER JOIN codes c2 ON c2.code_element_parent = c.code_element
GROUP BY c.code_element




Cette discussion est classé dans : arbre, compter, element, fils, niveaux


Répondre à ce message

Sujets en rapport avec ce message

compter les clics sur un lien [ par omnikod ] je voudrais savoir combien de fois tel ou tel lien a été cliqué (pour des download par exemple) c possible ? comment ? Compter des fichiers.... [ par FleX ] Alors voila. je voudrais me faire un script php3 qui compte le nombre de fichiers dans un dossier et que le resultat soit mis dans une variable, que j Compter les chiffre d'une colonne dans MySQL [ par Neozix ] Bonjour,Voila je souhaiterais compter les valeurs que j'ai dans une colonne, c'est une colonne qui contient des nombres de cd. cd -----1367je souhait compter le nombre de dimanche sur un intervalle de date [ par desrimaisd ] salut,je voudrais savoir si kelk'un connaitrait un moyen de savoir combien il y a de dimanche (en fait d'un jour en particulier, c pareil pour les aut Expression reguliere [ par wonesek ] $mois = array( "01" => "Janvier", "02" => "Fevrier", "03" => "Mars", "04" => "Avril", "05" => "Mai", "06" => "Juin", "07" => "Juillet", "08" => compter le nb d'impretion [ par cercleaventure ] PERSONNE n'a put repondre a mon probleme, donc je test ici.J'ai un javascript pour imprimer une page. jusque la tout va bien.MAIS j'aimerai pouvoir co PB Compter le nombre de posts par utilisateurs dans une table [ par the_snake ] Bonjour je cherche une solution pour compter le nombre de posts par utilisateurs dans une table exemple:J'ai une table mysql (article _tbl) ou sont in Sous-niveaux en MySQL ? [ par tryoruda ] Salut à tousJ'aimerais savoir s'il est possible de créer des sous-niveaux avec une base de données MySQL chez Free.Par exemple, plusieurs tables A, B, Compter les ouverture d'un envoi d'email [ par nlh ] Bonjours.... j'envoi un message a plein de jens d'un coup.... z'en faite pas je fait pas de spamming... :)je cherche a comptabilisé le taux d'ouvertu compter du temps [ par animallecter ] voilà mon souci, j'ai 1 champs "temps passé", qui est en "Char", dans 1 prog en php qui s'appuie sur 1 base en Mysql . Je doit écrire dans la base de


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,343 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.