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 :

Création d'une requête sous access


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Inscrit en
    Juin 2009
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 15
    Points : 18
    Points
    18
    Par défaut Création d'une requête sous access
    Bonjour,


    Je vous sollicite car j'essai sans succès de créer via requête la vue suivante.
    mon besoin est d'éviter les recordeset pour un souci de temps de traitement (table très volumineuse).

    Exemple des données sources ainsi que le résultat attendu :

    Données
    id prix
    -- ----
     1   3e
     2   3e
     3   4e
     4   4e
     5   3e
     6   5e
     7   5e
     8   4e
    Résultat attendu
    id_premier id_dernier prix
    ---------- ---------- ----
             1          2   3e
             3          4   4e
             5          5   3e
             6          7   5e
             8          8   4e
    Pour l'heure j'arrive à un résultat qui n'est pas satisfaisant en utilisant des min / max

    Résultat actuel non ok
    id_premier id_dernier prix
    ---------- ---------- ----
             1          5   3e
             3          8   4e
             6          7   5e

    Désolé pour la PJ, j'ai mon navigateur qui ne s'ouvre pas pour uploader mon exemple.

    D'avance merci,
    Cordialement

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Essayez ainsi :
    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
    19
      select MIN(id) as id_premier
           , MAX(id) as id_dernier
           , prix
        from ( select t1.id, t1.id - COUNT(t2.id) as grp, t1.prix
                 from MaTable as t1
                 join MaTable as t2
                   on t2.prix = t1.prix
                  and t2.id  <= t1.id
             group by t1.id, t1.prix) as SR
    group by grp, prix
    order by MIN(id) asc;
     
    id_premier  id_dernier  prix
    ----------- ----------- ----
    1           2           3e
    3           4           4e
    5           5           3e
    6           7           5e
    8           8           4e
    Attention, je n'ai pas d'Access sous la main, il pourrait y avoir des différences de syntaxe.

  3. #3
    Membre à l'essai
    Inscrit en
    Juin 2009
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 15
    Points : 18
    Points
    18
    Par défaut
    Bonjour et merci pour votre réponse (ainsi que pour votre rapidité)

    j'avais oublié un champs dans mon agrégat de ce fait j'ai essayé d'adapté votre proposition mais il me dit erreur dans la clause from

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
      SELECT PRODUIT
           , MIN(CODE_TAILLE) AS id_premier
           , MAX(CODE_TAILLE) AS id_dernier
           , PRIX_ACHAT
        FROM ( SELECT t1.PRODUIT,t1.CODE_TAILLE, t1.CODE_TAILLE - COUNT(t2.CODE_TAILLE) AS grp, t1.PRIX_ACHAT
                 FROM matable AS t1
                 JOIN matable AS t2
                   ON t2.PRIX_ACHAT = t1.PRIX_ACHAT
                  AND t1.PRODUIT = t2.PRODUIT
                  AND t2.CODE_TAILLE  <= t1.CODE_TAILLE
             GROUP BY t1.PRODUIT,t1.CODE_TAILLE, t1.PRIX_ACHAT) AS SR
    GROUP BY PRODUIT,grp, PRIX_ACHAT
    ORDER BY MIN(PRODUIT,CODE_TAILLE) ASC;
    le résultat attendu est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    produit id_premier id_dernier PRIX_ACHAT
    ------- --------- --------- ------------
    1              1           3             x€
    1              4           4             x€
    1              5           8             x€
    2 ....
    désolé pour cet oubli qui vous aura fait perdre votre temps.

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Je pense que vous avez bien incorporé le produit sauf dans la clause de tri :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ORDER BY PRODUIT ASC, MIN(CODE_TAILLE) ASC;
    Par contre, je ne sais pas si Access accepte les sous-requêtes (auquel cas il faudra la mettre dans une vue) ainsi que l'absence du mot INNER pour la jointure (auquel cas il faut le rajouter).

  5. #5
    Membre à l'essai
    Inscrit en
    Juin 2009
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Juin 2009
    Messages : 15
    Points : 18
    Points
    18
    Par défaut
    Super, merci effectivement j'avais loupé le trie.
    et access demande le inner

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [AC-2007] Comment échapper les (') dans une requête sous ACCESS 2
    Par yfchauer dans le forum IHM
    Réponses: 4
    Dernier message: 13/04/2013, 19h52
  2. [AC-2007] Comment échapper les (') dans une requête sous ACCESS
    Par yfchauer dans le forum IHM
    Réponses: 8
    Dernier message: 02/04/2013, 21h26
  3. Comment afficher le rang des résultats d'une requête sous Access 2002
    Par painpepper dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 15/08/2007, 01h19
  4. [Requête]Personnalisation d'access lors de la création d'une requête
    Par Jealous_Elf dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 29/03/2007, 11h07
  5. Types de données incompatibles lors d'une requête sous access
    Par RodEpsi dans le forum Bases de données
    Réponses: 32
    Dernier message: 21/07/2006, 15h51

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