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 :

Incrémentation conditionnelle dans une table


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 310
    Par défaut Incrémentation conditionnelle dans une table
    Bonjour à tous,

    J'ai une table dans laquelle j'aimerais rajouter un champs qui s'incrémenterait lorsque une des champs existant dans la table (champs Flag dans l'exemple) prendrait une certaine valeur (0). Peut être que la fonction rowno dans Oracle peut m'être utile.

    Présent:

    Nom : s1.jpg
Affichages : 147
Taille : 9,5 Ko

    Attendu:


    Nom : s2.jpg
Affichages : 135
Taille : 10,8 Ko


    Merci d'avance pour votre aide

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Bonjour

    Faites comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT cle, dt_debut, dt_fin, flag, SUM(CASE WHEN flag = 0 THEN 1 ELSE 0 END) OVER(ORDER BY dt_debut) AS compteur
    FROM Latable

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 310
    Par défaut
    Merci pour votre réponse aieeeuuuuu

    J'avais effectivement flagué à 1 les cas qui m'intéressaient mais ensuite je ne savais pas quoi en faire. On les somme donc.

    Par contre, j'ai un champs supplémentaire que j'avais pas mis dans mon exemple, c'est ID_AGENT. Et j'ai rajouté

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    OVER(ORDER BY ID_AGENT||'-'||DT_DEBUT)
    Mais ça ne marche pas pour certaines lignes . J'obtiens cela:

    Id_agent Clé Date_début Date_fin flag Compteur
    1016 2 07/01/16 07/01/16 0 2
    1023 3 08/01/16 12/02/16 1 2
    1023 4 13/02/16 14/02/16 1 2


    Alors que je voudrais que le compteur s'incrémente donc à chaque fois que l'id_agent change ou lorsque à l'intérieur d'un même id_agent le flag prend la valeur 0. Soit pour les premières lignes

    Id_agent Clé Date_début Date_fin flag Compteur
    1016 2 07/01/16 07/01/16 0 2
    1023 3 08/01/16 12/02/16 1 3
    1023 4 13/02/16 14/02/16 1 3

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Si flag est déjà le résultat d'un calcul, alors il faudra intégrer le changement de id_agent par exemple avec LEAD ou LAG

Discussions similaires

  1. Réponses: 1
    Dernier message: 12/05/2009, 11h05
  2. [A-03] Incrémentation enregistrement dans une table
    Par Xavierc dans le forum Modélisation
    Réponses: 2
    Dernier message: 26/02/2009, 14h07
  3. Modification conditionnelle du contenu d'un champ dans une table
    Par Lorenzole+bo dans le forum VBA Access
    Réponses: 6
    Dernier message: 17/07/2008, 22h14
  4. Comment obtenir un champs auto incrémenté dans une table DBase IV ?
    Par souminet dans le forum Bases de données
    Réponses: 1
    Dernier message: 11/12/2007, 13h55
  5. Réponses: 5
    Dernier message: 09/03/2007, 19h39

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