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

DB2 Discussion :

Requête compteur numéro d'occurrence pour un code donné


Sujet :

DB2

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 3
    Par défaut Requête compteur numéro d'occurrence pour un code donné
    Bonjour,

    J'essaie de me souvenir comment faire une requête SQL sous DB2 qui compte les occurrences par lignes selon un champ ... Qui peut m'aider ? Exemple :

    n°ocur code champ1 champ2
    1 01 100.00 568000
    2 01 100.00 548210
    1 05 100.00 588110
    1 09 100.00 588210
    1 10 100.00 548210
    2 10 100.00 588110
    3 10 100.00 588210
    1 11 100.00 588210

    Voilà je veux calculer n°ocur en fonction du nombre de répétitions du champ code. Et je galère un peu ! Merci beaucoup d'avance

  2. #2
    Membre Expert Avatar de bernard59139
    Profil pro
    Retired
    Inscrit en
    Octobre 2006
    Messages
    966
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Retired

    Informations forums :
    Inscription : Octobre 2006
    Messages : 966
    Par défaut
    ca?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT code, Count(*)
    FROM test
    group by code;

  3. #3
    Membre Expert

    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    1 298
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 298
    Par défaut
    J'essaierais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Select RANK() OVER (PARTITION BY Code ORDER BY Champ2) AS No_Occur, 
    Code, Champ1, Champ2
    FROM  MaTable
    ORDER BY Code, Champ1, Champ2

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 3
    Par défaut
    Merci Philippe je ne connaissais pas cette syntaxe ! Moi j'ai carrément fait autre chose de bien compliqué mais qui a marché) mais bon ça fait mal au cœur

    Je suis passé par deux tables temporaires toutes les deux numérotées de 1 à N enregistrements puis je fais des comparaisons entre elles pour chaque lignes.

    Mais merci beaucoup ça va beaucoup me servir cette fonction, c'est bizarre qu'on parle pas sur le net car j'ai fait nombre de forums avant de me décider à poser la question. Merci encore !

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Août 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 3
    Par défaut
    Seulement un petit hic, il faut visiblement à tout prix avec cette fonction un champ sur lequel elle va faire la rupture (order by champ2). Alors que moi dans ma table il peut y avoir deux lignes strictement identiques (Ce que j'ai fait le gère).

  6. #6
    Membre Expert

    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    1 298
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 298
    Par défaut
    Dans mon exemple, la partition ("rupture") se fait sur la colonne "CODE" et non pas sur la colonne "CHAMP2".

    Dans cette fonction OLAP, "ORDER BY Champ2" indique que l'ordre en question se fait sur la colonne "Champ2".

    Si cette fonction ne te convient pas, tu peux toujours essayer
    ou encore
    à la place de

Discussions similaires

  1. Réponses: 4
    Dernier message: 06/07/2010, 15h18
  2. Refaire cette requête pour mon code VBA
    Par majudis dans le forum VBA Access
    Réponses: 7
    Dernier message: 08/12/2009, 09h02
  3. Requête un peu trop compliqué pour moi
    Par Kokito dans le forum Langage SQL
    Réponses: 5
    Dernier message: 18/04/2005, 15h17
  4. pb eval pour le code php dans une feuille xslt
    Par nipepsi dans le forum XSL/XSLT/XPATH
    Réponses: 8
    Dernier message: 10/09/2004, 11h23

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