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

Langage SQL Discussion :

Stats de formules chimiques 2


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2008
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2008
    Messages : 27
    Points : 20
    Points
    20
    Par défaut Stats de formules chimiques 2
    Bonjour,

    j'ai un problème pour extraire des statistiques sur des formules chimiques.

    J'ai 2 tables dans ma base : une qui contient tout l'entête de la formule (numéro de formule, date de création, personne qui l'a créée, forme (liquide, pommade, ...), ...) et la 2e qui contient les composants avec leurs quantités :

    entête

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    num  forme      date
    1    pommade    2018-01-05
    2    pommade    2018-01-06
    3    liquide    2018-02-04
    4    liquide    2018-02-08
    détail de la formule

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    num  produit       qte  unité
    1    composant1    1    g
    1    composant4    0.8  g
    1    composant5    2    g
    2    composant1    1    g
    2    composant4    0.8  g
    2    composant5    2    g
    3    composant5    4    g
    3    composant8    2    g
    4    composant2    3    g
    4    composant3    1.2  g
    mon problème est de pouvoir savoir combien de fois chaque formule est présente et même avoir un indicateur me permettant de différencier les formules (pour celles qui ressortiraient le même nombre de fois).
    Avoir un résultat du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    nb   produit       qte  unité formule
    2    composant1    1    g     1
    2    composant4    0.8  g     1
    2    composant5    2    g     1
    1    composant5    4    g     2
    1    composant8    2    g     2
    1    composant2    3    g     3
    1    composant3    1.2  g     3
    Merci beaucoup pour votre aide

  2. #2
    Membre expérimenté
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Septembre 2016
    Messages
    776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2016
    Messages : 776
    Points : 1 488
    Points
    1 488
    Par défaut
    Bonsoir,

    Si je reformule le besoin ainsi est-ce juste ?
    "Considérant qu'une 'formule' est caractérisée par un ensemble de produit en une certaine quantité, lister les formules qui sont en double".

    Pour la suite il est important de savoir :
    - si l'ordre des composants est important pour caractériser la formule
    - si le protocole (température, pression, ...) est important pour caractériser la formule

    - le nom et la version du SGBD

  3. #3
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2008
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2008
    Messages : 27
    Points : 20
    Points
    20
    Par défaut
    Bonsoir,

    dans l'absolu, je ne veux pas que les formules qui ressortent plusieurs fois, juste les compter.

    Suivant la complexité de la réponse, on peut envisager, évidemment le mieux, que les composants n'ont pas un ordre obligatoirement (puisqu'une formule avec "Composant 1 1g + Composant 2 0.4g" est la même que "Composant 2 0.4g + Composant 1 1g". Il n'y a pas d'autre facteur à prendre en compte si ce n'est de pouvoir si possible rajouter un filtre suivant la forme présente dans la table entête.

    Je n'ai pas précisé le SGBD car actuellement c'est Pervasive et dans un futur plus ou moins proche, ça sera PostgreSQL.

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 302
    Points : 39 647
    Points
    39 647
    Billets dans le blog
    9
    Par défaut
    Bonjour,

    Je ne comprends pas quelle(s) règle(s) permet(tent) d'obtenir le résultat attendu

    Par exemple, dans la première ligne, que représente la valeur nb=2 ?

  5. #5
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2008
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2008
    Messages : 27
    Points : 20
    Points
    20
    Par défaut
    dans le résultat, la première colonne indique combien de fois on trouve la formule.

    Avec mon exemple la formule "composant1 1g + composant4 0.8 g + composant5 2g" se retrouve 2 fois

  6. #6
    Membre expérimenté
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Septembre 2016
    Messages
    776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2016
    Messages : 776
    Points : 1 488
    Points
    1 488
    Par défaut
    Bonjour,

    Je ne connais pas Pervasive et la doc à l'air absente d'internet
    On va essayer de faire avec

    LA question est : avez-vous le droit de faire des vues ?
    Si oui c'est cool, sinon, faudra faire des copier-collé.
    Ça marchera aussi mais c'est juste plus difficile (et long) à lire.

    On y va :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Create View V_Pdt_par_Formule as
    SELECT num, count(1) as NB_Pdt_Dans_Formule
    From Produit
    Group by num;
    Donc, si tout va bien on peut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM V_Pdt_par_Formule where num <10;
    On poursuit par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Create View V_Pdt_Et_Nb as
    Select P.num, P.produit, P.qte, P.unité, NB.NB_Pdt_Dans_Formule 
    From Produit P
    	join V_Pdt_par_Formule NB on NB.num = P.num
    A ce stade on a une vue qui nous donne une colonne de plus que ce qu'il existe dans la table.
    On peut s'en assurer par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from V_Pdt_Et_Nb where num <10;
    Et là on peut reformuler la demande initiale par :
    "lister l'ensemble des produits par formule avec le nombre de formules qui utilisent ce même ensemble"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    Select liste1.num 		
          , liste1.produit
          , liste1.qte 		
          , liste1.unité	
          , liste1.NB_Pdt_Dans_Formule
          , count(1) as NB_formule
    From V_Pdt_Et_Nb  					liste1	
    	left outer join V_Pdt_Et_Nb  	liste2
    		on  liste1.num 		< liste2.num 
    		And liste1.produit	= liste2.Produit
    		And liste1.qte 		= liste2.qte
    		And liste1.unité	= liste2.unité
    		And liste1.NB_Pdt_Dans_Formule = liste2.NB_Pdt_Dans_Formule 
    group by liste1.num 		
          , liste1.produit
          , liste1.qte 		
          , liste1.unité	
          , liste1.NB_Pdt_Dans_Formule
    On peut même en faire une vue

    Donnez nous des nouvelles

  7. #7
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 302
    Points : 39 647
    Points
    39 647
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par magicseb007 Voir le message
    dans le résultat, la première colonne indique combien de fois on trouve la formule.

    Avec mon exemple la formule "composant1 1g + composant4 0.8 g + composant5 2g" se retrouve 2 fois
    S'agit il de trouver les doublons stricts (numéro de formule différent mais composition identique) ou les intersections (numéro de formule différent, mais une partie de la formule F1 se retrouve dans la formule F2)

    Avec cet exemple
    F1 = produit1 100 grammes + produit2 50 grammes + produit3 12 grammes
    F2 = produit1 100 grammes + produit2 50 grammes + produit3 12 grammes + produit4 40 grammes
    F3 = produit2 50 grammes + produit3 12 grammes
    F4 = produit1 100 grammes + produit2 50 grammes + produit3 12 grammes + produit5 5 grammes

    quel est le résultat attendu ?

  8. #8
    Membre à l'essai
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Février 2008
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2008
    Messages : 27
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par escartefigue Voir le message
    S'agit il de trouver les doublons stricts (numéro de formule différent mais composition identique) ou les intersections (numéro de formule différent, mais une partie de la formule F1 se retrouve dans la formule F2)

    Avec cet exemple
    F1 = produit1 100 grammes + produit2 50 grammes + produit3 12 grammes
    F2 = produit1 100 grammes + produit2 50 grammes + produit3 12 grammes + produit4 40 grammes
    F3 = produit2 50 grammes + produit3 12 grammes
    F4 = produit1 100 grammes + produit2 50 grammes + produit3 12 grammes + produit5 5 grammes

    quel est le résultat attendu ?
    Le résultat serait que F1, F2, F3 et F4 apparaissent chacun 1 fois

  9. #9
    Membre expérimenté
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Septembre 2016
    Messages
    776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2016
    Messages : 776
    Points : 1 488
    Points
    1 488
    Par défaut
    Bonjour magicseb007,

    La solution proposée ne fonctionne pas ?
    Pourquoi ?

    A bientôt

  10. #10
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 302
    Points : 39 647
    Points
    39 647
    Billets dans le blog
    9
    Par défaut
    Citation Envoyé par magicseb007 Voir le message
    Le résultat serait que F1, F2, F3 et F4 apparaissent chacun 1 fois
    en ce cas une simple détection de doublon suffit



    Citation Envoyé par Michel.Priori Voir le message
    Bonjour magicseb007,

    La solution proposée ne fonctionne pas ?
    Pourquoi ?

    A bientôt
    Peut être, mais il y a beaucoup plus simple du coup

  11. #11
    Membre expérimenté
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Septembre 2016
    Messages
    776
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2016
    Messages : 776
    Points : 1 488
    Points
    1 488
    Par défaut
    Citation Envoyé par escartefigue Voir le message
    Peut être, mais il y a beaucoup plus simple du coup
    Sans null doute
    Mais la demande initiale comporte la colonne "nb"...

    Je n'ai pas compris comment cette colonne sera exploitée car pour repérer 2 lots de produits, différents et successifs, dans la liste faut super bien connaitre ses données.
    C'est un peu pour ça que j'ai ajouté la colonne "num".

    Pour l'instant pas de réponse.
    A suivre.

Discussions similaires

  1. Stats de formules chimiques
    Par magicseb007 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 21/03/2018, 21h18
  2. Numération formule chimique + équation physique différentes
    Par Ni_Dieux_Ni_Maitre dans le forum Mathématiques - Sciences
    Réponses: 1
    Dernier message: 11/08/2011, 17h21
  3. [A-07]entrer une formule chimique dans un formulaire
    Par basalte dans le forum Modélisation
    Réponses: 1
    Dernier message: 12/03/2009, 09h27
  4. Outils pour formule chimique
    Par Ravens dans le forum Editeurs / Outils
    Réponses: 13
    Dernier message: 20/11/2008, 20h51
  5. Comment entrer des formules chimiques dans les champs access
    Par Monbasinstinct dans le forum Access
    Réponses: 18
    Dernier message: 06/04/2006, 17h39

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