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 :

Mon script de commande sql ne s'execute pas !


Sujet :

SQL Oracle

  1. #1
    Battosaiii
    Invité(e)
    Par défaut Mon script de commande sql ne s'execute pas !
    Bonjour,

    J'ai réalisé un script qui devrait permettre de updater une table radiologie.
    Malheureusement le script ne fait rien car la table n'est pas modifiée.
    Il n'y a pas d'erreur dans le log non plus.
    Voici le script :

    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
     
    function updateRadiologieTable
    {
    sqlplus -s /nolog >/dev/null  <<-EOF
    connect $SCHEMA/$SCHEMAPW
     
    set trimspool on
    spool /app/bsr/MDE1BSR/home/users/amde1bsr/update_table_radiologie.log 
     
    whenever sqlerror exit 1;
     
     
    UPDATE radiologie rad
       SET (rad.uh_demandeuse,rad.nip) = (SELECT sda.code_uh_demande,sda.nip_actif
    	   		FROM SAG_DATA_TEMP sda
    	   		   	WHERE CONCAT(rad.ID_DEMANDE, rad.ID_EXAMEN) = sda.s_aphp_reference_acte_rados)
    			WHERE CONCAT(rad.ID_DEMANDE, rad.ID_EXAMEN) in (select s2.ref from SAG_DATA_TEMP s2)
     
     
    spool off
    exit
    EOF
    }

    Pourtant la commande sql marche depuis mon client Toad .

    Lorsque j'execute cette commande ci dessous la table radiologie est executée correctement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     
    UPDATE radiologie rad
       SET (rad.uh_demandeuse,rad.nip) = (SELECT sda.code_uh_demande,sda.nip_actif
    	   		FROM SAG_DATA_TEMP sda
    	   		   	WHERE CONCAT(rad.ID_DEMANDE, rad.ID_EXAMEN) = sda.s_aphp_reference_acte_rados)
    			WHERE CONCAT(rad.ID_DEMANDE, rad.ID_EXAMEN) in (select s2.ref from SAG_DATA_TEMP s2)
    Merci

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    il manque le commit

  3. #3
    Membre Expert Avatar de ojo77
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Décembre 2010
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2010
    Messages : 680
    Par défaut
    Non, il manque un point-virgule en fin d'update.
    Dans sqlplus la commande exit effectue un commit si on ne précise pas de code de retour différent de 0.

  4. #4
    Battosaiii
    Invité(e)
    Par défaut
    Merci pour vos reponses.

    Effectivement ojo77 a raison. C'était un problème de point virgule !

Discussions similaires

  1. [MySQL] Mon script php et sql genere une erreur pourquoi ?
    Par booster71 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 16/07/2014, 08h05
  2. Problème lors de l'exécution de mon script en PL SQL
    Par peregna2007 dans le forum PL/SQL
    Réponses: 1
    Dernier message: 21/06/2010, 22h48
  3. Réponses: 5
    Dernier message: 21/08/2007, 13h47
  4. commande SQL qui ne fonctionne pas
    Par Flavien44 dans le forum VBA Access
    Réponses: 5
    Dernier message: 13/06/2007, 16h40
  5. ORA-00933 la commande SQL ne se termine pas correctement
    Par habasque dans le forum Sql*Plus
    Réponses: 1
    Dernier message: 09/12/2006, 14h41

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