IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

EDI, CMS, Outils, Scripts et API PHP Discussion :

Permettre un ordonnancement à chaque génération d'une structure arborescente


Sujet :

EDI, CMS, Outils, Scripts et API PHP

  1. #1
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut Permettre un ordonnancement à chaque génération d'une structure arborescente
    Bonjour,

    Je me doute que mon objectif va nécessiter PHP + mysql + javascript.

    Voici le genre de problématique

    1) J'ai dans ma base une table arbre avec toute les structures de mon entreprise (qui est grosse : 182 noeuds), bien entendu, c'est une structure hiérarchique donc avec une auto-jointure.

    2) Tout serait simple si je pouvais ensuite présenter une arborescence dynamique avec l'ordre alphabétique (déjà fait).

    Ce qui me complique tout, c'est que la MOA veut pouvoir classer de façon protocolaire, à chaque étape de la filiation, les structures et services sur chaque page.

    3) j'ai donc construit la vue suivante (appelons-là v_ordre) qui s'appuie sur la table ordre qui se contente d'avoir elle un id, stru_id (jointure externe avec le stru_id de la table arbre),et rang

    id stru_id stru_code lib_court lib_long rang
    49 305 TOTO_PILOTAGE Pilotage Pilotage central 01N01
    50 306 TOTO_PILOTAGE_FRANCE Pilotage France Pilotage de TOTO France 01N02
    51 307 TOTO_PILOTAGE_ETRANGER Pilotage étranger Pilotage de TOTO étranger 01N03
    52 308 TOTO_PILOTAGE_ETRANGER_ASIE Pilotage Asie Pilotage de TOTO Asie 01N03N01

    Il me faut donc leur offrir une interface d'administration pour que le secrétariat puisse avoir la main là-dessus.

    Voici donc mes questions :

    1) L'interface idéale et la plus intuitive est la suivante : elle clique sur un noeud, les enfants se déroulent, et elle a la possibilité de monter ou descendre chacun d'eux comme ça lui chante (javascript).
    2) Quand elle valide, je passe en PHP et MYSQL dans la table ordre l'ordre choisi.
    3) comment au fait pour coder rang ?
    3a)J'ai d'abord pensé à un numérique simple par rapport à son noeud, pour m'aider ensuite du champ stru_code... mais mysql ne sait pas ensuite me reconstruire TOUT l'ordonnancement depuis le début, car je n'ai pas trouvé en SQL d'équivalent substr_count...
    3b) alors je me suis rabattu sur un champ rang plus lourd (et plus redondant j'en ai conscience) mais qui me permet tout de suite d'utiliser un simple order by rang. Problème, quand elle modifiera, il faudra que je modifie via PHP tous les rangs de ses enfants...

    Je compte sur vos lumières !

    Par ailleurs, je n'ai jamais codé le 1, si vous avez des lumières.

    Un grand merci d'avance !
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 235
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 235
    Points : 15 532
    Points
    15 532
    Par défaut
    Ce projet à l'air bien fourni, vous feriez mieux de le découper en petite tâche pour mieux avancer.

    Pour commencer, je stockerai dans la table l'identifiant du parent et le rang séparément. Ainsi le changement de parent et le changement d'ordre parmi les éléments frères sont deux taches indépendantes.

    En ce qui concerne l'interface avec JavaScript, il y a d'un côté le code JavaScript qui fait l'appel (et traite la réponse) et de l'autre le code PHP qui répond donc là aussi cela fera plusieurs choses à étudier séparément.

Discussions similaires

  1. Réponses: 6
    Dernier message: 11/09/2013, 08h13
  2. Analyser une structure arborescente avec menhir
    Par sulu45 dans le forum Caml
    Réponses: 5
    Dernier message: 04/09/2012, 08h08
  3. Génération d'une structure de fichier automatique
    Par Aymeric00 dans le forum Eclipse Platform
    Réponses: 2
    Dernier message: 12/01/2011, 09h18
  4. Réponses: 3
    Dernier message: 13/01/2010, 14h28
  5. longueur d'une structure
    Par bohemianvirtual dans le forum C
    Réponses: 6
    Dernier message: 28/05/2002, 18h31

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo