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

SQL Oracle Discussion :

UPDATE incrémental par contenu


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Santé

    Informations forums :
    Inscription : Septembre 2011
    Messages : 2
    Par défaut UPDATE incrémental par contenu
    Bonjour,

    Comment mettre à jour une colonne avec un compteur de ligne qui se réinitiallise pour chaque valeur ?
    Par ex, la table :
    A 0
    B 0
    A 0
    A 0
    C 0
    B 0
    A 0 ....
    Devient :
    A 1
    B 1
    A 2
    A 3
    C 1
    B 2
    A 4 ......

    Ca parait facile mais je n'y arrive pas avec un simple sql UPDATE.
    Si vous avez des pistes, je suis preneur.

    Merci d'avance

    David

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Février 2010
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 412
    Par défaut L'oeil du faucon

  3. #3
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
     
    Connected to Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 
    Connected as mni
     
    SQL> 
    SQL> create table test_upd as
      2  Select 'A' id, 0 rank from dual union all
      3  Select 'B', 0 from dual union all
      4  Select 'A', 0 from dual union all
      5  Select 'A', 0 from dual union all
      6  Select 'C', 0 from dual union all
      7  Select 'B', 0 from dual union all
      8  Select 'A', 0 from dual
      9  /
     
    Table created
    SQL> Select *
      2    from test_upd
      3  /
     
    ID       RANK
    -- ----------
    A           0
    B           0
    A           0
    A           0
    C           0
    B           0
    A           0
     
    7 rows selected
    SQL> merge Into test_upd d
      2    using (select rowid, row_number() over(partition by id order by rowid) nouveau_rank
      3            from test_upd
      4          ) s
      5      On (d.rowid = s.rowid)
      6  when matched then update set d.rank = s.nouveau_rank
      7  /
     
    Done
    SQL> Select *
      2    from test_upd
      3  /
     
    ID       RANK
    -- ----------
    A           1
    B           1
    A           2
    A           3
    C           1
    B           2
    A           4
     
    7 rows selected
     
    SQL>

  4. #4
    Candidat au Club
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Santé

    Informations forums :
    Inscription : Septembre 2011
    Messages : 2
    Par défaut
    Excellent, c'est exactement cela.
    Il me manquait l'astuce avec le ROWID.

    Encore merci à tous.

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 09/08/2007, 08h11
  2. requéte insert /update/delete par dataAdapter
    Par magui_laurene dans le forum Accès aux données
    Réponses: 1
    Dernier message: 02/08/2007, 14h12
  3. [Débutant] Requête Insert ou Update exécutée par l’objet ADO
    Par lazerdev dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 11/05/2007, 10h52
  4. incrémentation par année
    Par pascual dans le forum Access
    Réponses: 11
    Dernier message: 15/07/2006, 13h12
  5. Appel de procédure par contenu de variable
    Par lil_jam63 dans le forum Langage
    Réponses: 9
    Dernier message: 13/09/2004, 08h05

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