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

Oracle Discussion :

[Merge] Pas d'insertion


Sujet :

Oracle

  1. #1
    Membre habitué Avatar de VinceTlse
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    163
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 163
    Points : 191
    Points
    191
    Par défaut [Merge] Pas d'insertion
    Bonjour,
    J'essaie pour la premiere fois de faire un MERGE.
    - si je trouve l'id -> UPDATE
    - si je ne le trouve pas -> INSERT

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    MERGE INTO SYNCHRO_DOSSIERS e
    USING SYNCHRO_DOSSIERS h
    ON (e.DOSSIER_ID = h.DOSSIER_ID AND h.DOSSIER_ID = 13095)
    WHEN MATCHED THEN
        UPDATE SET TYPE_ETAT_SYNCHRO_ID = PACKAGE_CONSTANTES.C_TYPE_ETAT_SYNCHRO_WAITING
    WHEN NOT MATCHED THEN
        INSERT (DOSSIER_ID, TYPE_ETAT_SYNCHRO_ID, SYNCHRO_DOSSIERS_COMMENT, SYNCHRO_DOSSIERS_DATE_DEM, SYNCHRO_DOSSIERS_DATE_DEB, SYNCHRO_DOSSIERS_DATE_FIN)
        VALUES (13095, PACKAGE_CONSTANTES.C_TYPE_ETAT_SYNCHRO_WAITING, NULL, SYSDATE, NULL,NULL);
    Lorsque l'id existe, la mise à jour se fait sans problème.
    Mais s'il n'existe pas, la ligne n'est pas insérée. (0 rows merged)

    Avez vous une idée de se qui ne va pas dans ma requete?
    Version: 9.2.0.7
    Je vous remercie par avance!

    Vincent
    Pourquoi faire aujourd'hui ce que l'on peut faire demain ...

  2. #2
    Membre confirmé Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Points : 603
    Points
    603
    Par défaut
    Essais de réécrire la clause USING de ton merge comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    MERGE INTO SYNCHRO_DOSSIERS e
    USING (select * from SYNCHRO_DOSSIERS where DOSSIER_ID = 13095) h 
    ON (e.DOSSIER_ID = h.DOSSIER_ID)
    WHEN MATCHED THEN
        UPDATE SET TYPE_ETAT_SYNCHRO_ID = PACKAGE_CONSTANTES.C_TYPE_ETAT_SYNCHRO_WAITING
    WHEN NOT MATCHED THEN
        INSERT (DOSSIER_ID, TYPE_ETAT_SYNCHRO_ID, SYNCHRO_DOSSIERS_COMMENT, SYNCHRO_DOSSIERS_DATE_DEM, SYNCHRO_DOSSIERS_DATE_DEB, SYNCHRO_DOSSIERS_DATE_FIN)
        VALUES (13095, PACKAGE_CONSTANTES.C_TYPE_ETAT_SYNCHRO_WAITING, NULL, SYSDATE, NULL,NULL);
    Nicolas.

  3. #3
    Membre habitué Avatar de VinceTlse
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    163
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 163
    Points : 191
    Points
    191
    Par défaut
    Merci pour votre réponse.
    Malheureusement il n'y a pas d'amélioration, l'insertion ne se fait toujours pas.
    Pourquoi faire aujourd'hui ce que l'on peut faire demain ...

  4. #4
    Membre confirmé Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Points : 603
    Points
    603
    Par défaut
    Est-ce possible de poster le contenu de chaque table (ou tout du moins un extrait suffisament significatif) ?

    Nicolas.

  5. #5
    Membre habitué Avatar de VinceTlse
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    163
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 163
    Points : 191
    Points
    191
    Par défaut
    Bien sûr!
    Description de la table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    >>desc SYNCHRO_DOSSIERS;    
     
    Name                       Null      Type         
    -------------------------  --------  -------------
    DOSSIER_ID                 NOT NULL  NUMBER       
    TYPE_ETAT_SYNCHRO_ID       NOT NULL  NUMBER       
    SYNCHRO_DOSSIERS_COMMENT             VARCHAR2(256)
    SYNCHRO_DOSSIERS_DATE_DEM  NOT NULL  DATE         
    SYNCHRO_DOSSIERS_DATE_DEB            DATE         
    SYNCHRO_DOSSIERS_DATE_FIN            DATE
    Exemples de données:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    >>SELECT * FROM SYNCHRO_DOSSIERS;
     
    DOSSIER_ID | TYPE_ETAT_SYNCHRO_ID | SYNCHRO_DOSSIERS_COMMENT |	SYNCHRO_DOSSIERS_DATE_DEM |	SYNCHRO_DOSSIERS_DATE_DEB |	SYNCHRO_DOSSIERS_DATE_FIN
    -------------------------------------------------------------------------------------------------------------------------------------------------
    13101      | 0	                  |	                         |  27/02/07                  |                           |
    13105      | 3	                  | Toto a la plage          |  27/02/07	                | 27/02/07                  | 27/02/07
    13095      | 1                    |                          |  27/02/07  	              | 27/02/07                  |
    Pourquoi faire aujourd'hui ce que l'on peut faire demain ...

  6. #6
    Membre confirmé Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Points : 603
    Points
    603
    Par défaut
    Ok, j'avais pas vu qu'il ne s'agissait que d'une table (et non deux).
    Bon, alors essaies plutôt ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    MERGE INTO SYNCHRO_DOSSIERS e
    USING (SELECT 13095 as  DOSSIER_ID FROM DUAL) h 
    ON (e.DOSSIER_ID = h.DOSSIER_ID)
    WHEN MATCHED THEN
        UPDATE SET TYPE_ETAT_SYNCHRO_ID = PACKAGE_CONSTANTES.C_TYPE_ETAT_SYNCHRO_WAITING
    WHEN NOT MATCHED THEN
        INSERT (DOSSIER_ID, TYPE_ETAT_SYNCHRO_ID, SYNCHRO_DOSSIERS_COMMENT, SYNCHRO_DOSSIERS_DATE_DEM, SYNCHRO_DOSSIERS_DATE_DEB, SYNCHRO_DOSSIERS_DATE_FIN)
        VALUES (h.DOSSIER_ID, PACKAGE_CONSTANTES.C_TYPE_ETAT_SYNCHRO_WAITING, NULL, SYSDATE, NULL,NULL);
    Nicolas.

  7. #7
    Membre habitué Avatar de VinceTlse
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    163
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 163
    Points : 191
    Points
    191
    Par défaut
    Merci NGasparotto,

    Ta solution marche à merveille.
    Par contre je n'ai pas très bien compris la cause. Si tu as le temps, je veux bien une toute petite explication.
    Sinon, tu ne serais pas de C-S Tlse? Ton nom me dit quelque chose.
    Merci beaucoup pour ton aide.

    Vincent
    Pourquoi faire aujourd'hui ce que l'on peut faire demain ...

  8. #8
    Membre confirmé Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Points : 603
    Points
    603
    Par défaut
    Bien, on va essayer une petite explication.

    MERGE INTO
    Tu merge dans une table dans laquelle il n'y a priori pas ta ligne 13095, ok ?

    USING
    Tu utilise une table (la même en l'occurence) en restreignant sur la ligne 13095.
    * Si cette ligne existe ici, elle existe aussi dans la table dans laquelle tu merge (puisque la table est la même), donc la jointure est vérifiée, donc tu rentres dans WHEN MATCHED et l'update.
    * Si cette ligne n'existe pas dans ta deuxième, elle n'existe pas non plus dans dans la première table (puisque ta première table - celle du MERGE INTO - est la même), donc ni dans l'une ni dans l'autre... donc pas de jointure du tout.

    Pour pouvoir merger, autrement dit pour effectuer une jointure - ta clause ON -, il te faut au moins une ligne pour pouvoir dire qu'elle est de l'autre côté ou non, non ?
    D'où, dans ton cas précis, l'utilisation de la table DUAL qui te renverra de toute façon la ligne 13095, et regardes si elle est ou non dans ta table dans laquelle tu fais le merge.

    Sinon, oui CS Toulouse...

    Nicolas.

Discussions similaires

  1. hibernate, flush ne faisant pas d'insert..
    Par Djef-69 dans le forum Persistance des données
    Réponses: 3
    Dernier message: 26/02/2011, 20h25
  2. ORDER BY RAND() ne fonctionne pas dans INSERT
    Par cedrick21 dans le forum Requêtes
    Réponses: 1
    Dernier message: 17/08/2010, 11h46
  3. Réponses: 12
    Dernier message: 23/01/2010, 21h41
  4. Verifier qu une ligne existe ou pas pour insertion
    Par ZashOne dans le forum Accès aux données
    Réponses: 8
    Dernier message: 25/02/2009, 00h55
  5. [web] [Perl/Tk] Pas d'insertion de texte !
    Par GLDavid dans le forum Interfaces Graphiques
    Réponses: 2
    Dernier message: 08/07/2004, 22h00

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