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

Développement SQL Server Discussion :

Arbre et table de décision


Sujet :

Développement SQL Server

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 118
    Points : 27
    Points
    27
    Par défaut Arbre et table de décision
    Bonjour,

    Dans le cadre d'un progiciel de tri, je souhaite représenter et exécuter un arbre de décision dans la base. L'arbre représente les conditions et les valeurs permettant de déterminer la sortie d'un colis sur un trieur. Il a pour but de remplacer la structure traditionnelle de plan de tri avec une table de détail dont les colonnes représentent les critères de tri. Cette structure n'est pas évolutive ni modifiable. De plus elle impose que le code soit adapté aux critères. Impossible d'en ajouter sans modifier le code.

    Je m'oriente donc vers un arbre de décisions pour faire cela.
    Cet arbre est majoritairement non binaire, il travaille avec des valeurs discrètes qui mènent à des branches selon leur valeur. Il sera utilisé uniquement en lecture pour le processus de tri. Il sera construit 'manuellement' (avec une application), puis utilisé pour un grand nombre de colis.

    Tout d'abord, j'ai pensé me faire tout cela par code en me débrouillant pour stoker l'arbre dans la base. Puis je me suis ravisé en regardant du coté des tables de décision. Le problème est qu'elles traitent la plupart du temps d'arbres binaires. Je ne trouve pas d'exemple qui se rapproche de mon cas. Enfin, si j'ai bien compris, la table de décision utilise des colonnes pour représenter les conditions. Cela pose deux problèmes :
    1 - j'ai toujours lu qu'il est très mal de modifier la structure de la base de données selon les besoins du client. Une bonne modélisation permet d'avoir une structure fixe qui s'adapte a tous les besoins
    2 - Il me parait difficile d'indexer correctement une table dont la nature et le nombre de colonnes est inconnu lors de la conception.

    Je me dis donc qu'il existe peut être des astuces pour gérer un arbre de décisions.
    Le but premier de mon post est de savoir comment mettre dans la base une telle structure,
    savoir si je peux utiliser une table de décisions et si c'est performant
    et le top serait que je puisse faire une requête qui pourrait lire l'arbre et me renverrait la décision prise.

    Un exemple : j'ai une table colis qui comporte entre autres choses un poids et un code postal. Chaque plage de code postaux est associée à une sortie
    Si le poids est supérieur à un seuil, alors les associations des codes postaux sont différentes.
    Autre exemple : Chaque colis comporte une date de limite de vente et un code magasin. Si la DLV est périmée, la sortie sera fixe, sinon le colis sera trié selon le code du magasin (avec une association magasin<->sortie donc)


    Merci pour votre aide !!

    PS : je suis sous sql serveur 2008.

    Edit : ortho

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 766
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 766
    Points : 52 563
    Points
    52 563
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    pour la modélisation des arbres, voir les nombreux papier que j'ai écrit :
    http://sqlpro.developpez.com/cours/arborescence/
    http://blog.developpez.com/sqlpro/p7...dure-de-derec/
    http://blog.developpez.com/sqlpro/p7...dure-de-depla/
    http://blog.developpez.com/sqlpro/p8...allaire-proce/

    Bien entendu vous n'êtes pas obligé d'adopter cette méthode et dans ce cas vous aurez besoin de requêtes récursives :
    http://sqlpro.developpez.com/cours/s...te-recursives/

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 118
    Points : 27
    Points
    27
    Par défaut
    Merci pour cet précision.

    J'ai effectivement bien étudié ces excellent papiers sur les arbres dans la base .
    Grâce à cela, l'arbre en lui même ne me pose pas de problème (bien que je sache aussi gérer la récursivité).

    Ce qui est problématique c'est les décisions. Je ne sais pas comment faire à partir de l'arbre pour prendre la décision par un parcours.
    Comme je l'ai indiqué, j'ai regardé vers les tables de vérité mais cela me semble peu efficace.

    D'où ma question : est il préférable de le faire avec du code (C++) ou bien cela est il réalisable -grâce à des astuces- par une requête ?

    Merci

  4. #4
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 766
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 766
    Points : 52 563
    Points
    52 563
    Billets dans le blog
    5
    Par défaut
    Par requête, probablement en logique flou.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Octobre 2009
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 118
    Points : 27
    Points
    27
    Par défaut
    Merci, je vais regarder de ce coté là

Discussions similaires

  1. [WD11] Drag and drop arbre vers table
    Par sycoulibaly dans le forum WinDev
    Réponses: 0
    Dernier message: 01/03/2011, 14h04
  2. [WD15] Arbre,Treeview + Table
    Par Trusty823 dans le forum WinDev
    Réponses: 2
    Dernier message: 08/11/2010, 22h34
  3. [WD14] D&D entre arbre et table
    Par Lolo7287 dans le forum WinDev
    Réponses: 1
    Dernier message: 04/02/2010, 11h24
  4. Bonne pratique pour une table de décision
    Par Nalfeim dans le forum Langage
    Réponses: 3
    Dernier message: 19/08/2009, 11h30
  5. Drools : Partage d'un objet entre 2 tables de décisions
    Par nicokrz dans le forum Wildfly/JBoss
    Réponses: 1
    Dernier message: 26/08/2008, 16h21

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