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 :

[Oracle 92]Merge - ora-600


Sujet :

Oracle

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    77
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 77
    Points : 84
    Points
    84
    Par défaut [Oracle 92]Merge - ora-600
    J'ai été confronté à un bug Oracle lors d'un merge avec une requête complexe dans le using. Lors du parse (ça plante aussi bien en explain plan qu'en execute), j'ai une erreur ora-600 [qkaUpsertRowVec1].

    Il y a des bugs référencé présent sur metalink, mais sans aucune solution.

    J'ai malgré tout réussi à trouver un contournement.

    Voici la version qui plante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    merge into toto
    using (select ... from tres compliqué)  source
    on (toto.primary_key=source.primary_key)
    when matched then
    update ...
    when not matched then
    insert ...
    Si je modifie comme suit, ça marche :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    merge into toto
    using ( with temp as (select /*+ MATERIALIZE */ ... from tres compliqué) select * from temp)  source
    on (toto.primary_key=source.primary_key)
    when matched then
    update ...
    when not matched then
    insert ...
    Le principe :
    je transforme la requête complexe en requête trés simple et je remonte la complexité dans un with que je matérialise sur le temp. D'ou l'importance du hint materialize (attention : non documenté, donc certains clients peuvent refuser).

    Une autre solution, plus lourde mais sans le hint non documenté : créer une global temporary table, faire un insert select dedans et n'avoir qu'un select * from la_table_temporaire.

    bon week

    Hugues

  2. #2
    Expert éminent sénior
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 073
    Points
    19 073
    Par défaut
    Merci pour l'info

    J'en profite pour signaler que si le MERGE propose une fonction très intéressante elle souffre malheureusement de trop nombreux bug au moins en 9i... soyez donc prudent dans son utilisation

  3. #3
    Membre du Club
    Femme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2004
    Messages
    46
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Avril 2004
    Messages : 46
    Points : 43
    Points
    43
    Par défaut
    Bonjour

    Je suis en 10.2.0.2.
    Est-ce que les bugs sur le MERGE sont moins nombreux dans cette version ?


    J'ai un peu regardé sur le forum mais je n'ai pas trouvé d'ínfos concernant les perfs du MERGE. Est-ce que quelqu'un a des données la-dessus ? Comment fonctionne Oracle de maniere interne, quand il fait un MERGE ?
    Merci pour toute info ou lien vers l'endroit ou je pourrais trouver ce genre de choses.

    Est-ce que vous avez déja utilisé le MERGE sur une table "target" partitionnée ? Est-ce qu'on peut utiliser une table temporaire comme table source ?

    Merci d'avance

Discussions similaires

  1. [Oracle 9i]: erreur ORA-01925 (max enables roles)
    Par NPortmann dans le forum Oracle
    Réponses: 2
    Dernier message: 30/03/2007, 09h39
  2. [Forms10g/oracle 9i] erreur ORA-01652
    Par marcalexis dans le forum Oracle
    Réponses: 6
    Dernier message: 14/02/2006, 18h30
  3. Réponses: 4
    Dernier message: 21/11/2005, 12h04
  4. [Oracle Lite 10g]ORA-00957: duplicate column name
    Par maredami dans le forum Oracle
    Réponses: 4
    Dernier message: 02/11/2005, 13h13
  5. ora 600 via sunopsis
    Par bchaz dans le forum Oracle
    Réponses: 2
    Dernier message: 01/06/2005, 15h55

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