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

PL/SQL Oracle Discussion :

Problème de Merge


Sujet :

PL/SQL Oracle

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    394
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 394
    Par défaut Problème de Merge
    Bonjour,

    Voici mon code:
    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
     
    Merge INTO Table1 A
        USING (SELECT
                  D.CHAMP1,
                  B.CHAMP2,
                  E.CHAMP3,
                  B.CHAMP4,
                  B.CHAMP5,
                  B.CHAMP6,
                  B.CHAMP11
                 FROM Table2 B, Table3 C, Table4 D, Table5 E
                WHERE
                  D.CHAMP7 = B.CHAMP8
                  AND B.CHAMP12  = 'AAAAA'
                  AND E.TYPE='VALEUR1'
                  AND UPPER(E.LIBELLE)=UPPER(B.CHAMP9)
                  AND E.CHAMP3=1
                  AND CHAMP10 = CURSEUR.CHAMP10
                  AND B.CHAMP11 = C.CHAMP11
                  ) F
     
        ON ( ......)
     
        When Matched Then
          UPDATE
     
        When Matched Then
          UPDATE
    Peut-on mettre un CASE WHEN dans la partie

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    When NOT Matched Then
          INSERT
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    When NOT Matched Then
          INSERT
    Merci d'avance pour votre aide.

    Un peu de mal avec Merge !!!

    A+

  2. #2
    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
    Je ne pense pas (regarde la syntaxe du merge). Mais peux tu détailler ce que tu veux faire ?

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    394
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 394
    Par défaut
    Il y a un statut retourné par le select et dans un cas je ne veux pas faire d'update.

    Je ne peux pas mettre non plus çà dans la clause Where de mon Select, d'où mon idée faire un CASE.

  4. #4
    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
    Mais probablement que tu peux faire quelque chose de type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Merge Into emp2 d
    Using (Select * from emp) s
       On (d.empno = s.empno)
     When Matched Then
          Update Set d.sal = Decode(s.job,'SALESMAN',s.sal*1.1, s.sal)
     When Not Matched Then 
          Insert Values(s.empno, s.ename, s.job, s.mgr, s.hiredate, s.sal, s.comm, s.deptno)
    L'idée étant de mettre à jour avec la même valeur (j'aime pas ça, mais ...).

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    394
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 394
    Par défaut
    Effectivement le DECODE résoud mon problème.

    Surtout que c'est dans un seul cas. Bon par contre c'est un peu
    long car il faut que je fasse çà pour un vingtaine de champs.
    Mais on a rien sans rien !

    Merci mnitu !

    A+

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

Discussions similaires

  1. Problème avec Merge
    Par Thomad dans le forum PL/SQL
    Réponses: 1
    Dernier message: 16/07/2008, 22h11
  2. Problème Intruction MERGE
    Par ttamttam dans le forum PostgreSQL
    Réponses: 0
    Dernier message: 08/06/2008, 14h56
  3. [Utilisation] Problème de merge
    Par goetzilla dans le forum Subversion
    Réponses: 2
    Dernier message: 11/01/2008, 19h17
  4. 9i : problème avec MERGE INTO
    Par Vld44 dans le forum SQL
    Réponses: 1
    Dernier message: 16/08/2007, 11h27
  5. Problème de MERGE
    Par cyrille_ dans le forum SQL
    Réponses: 20
    Dernier message: 15/06/2007, 12h19

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