Précédent   Forum des professionnels en informatique > Bases de données > Oracle > Outils
Outils Forum d'entraide sur les outils pour Oracle
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 24/01/2008, 15h03   #1
Membre du Club
 
Inscription : juin 2006
Messages : 206
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 206
Points : 47
Points : 47
Par défaut Appel d'un script sqlplus depuis crontab

Bonjour à tous,

J'ai un script shell execute_sript.sh sous linux qui appelle une commande sqlplus
Ce script sqlplus fait appel à un fichier sql : papa.sql
dans ce fichier papa.sql sont appelé d'autre fichiers fils1.sql, fils2.sql

Autrement dit :
mon script linux contient la ligne suivante :
Code :
1
2
 
sqlplus login/pass@tns @papa.sql
dans mon fichier papa.sql j'ai les lignes suivantes :
Code :
1
2
3
 
@repertoire/fils1.sql
@repertoire/fils2.sql
Si j'execute mon script en ayant pris soin de me placer dans le même répertoire que papa.sql, mon script fonctionne.

Par contre si je l'appelle depuis le cron ou d'un autre reperoire de la manière suivante :
/home/user/execute_sript.sh
j'ai les erreurs suivantes :
Code :
SP2-0310: unable TO open file "repertoire/fils1.sql"
Sachant que je ne peux pas savoir à l'avance où les utilisateur vont placer le dossier contenant mon script et les fichiers sql,
Ma question est la suivante : comment dans mon script dire qu'il faut que je me mette dans le bon répertoire, commande linux ou sql.

Je précise que si je fait
Code :
cd /home/user/; ./execute_sript.sh
Mon script fonctionne, par contre si je mets la même ligne dans le cron, ca marche pô

Merci de votre aide
crazykangourou est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2008, 09h26   #2
Membre du Club
 
Inscription : janvier 2008
Messages : 50
Détails du profil
Informations forums :
Inscription : janvier 2008
Messages : 50
Points : 47
Points : 47
As-tu essayé :
Code :
1
2
@@repertoire/fils1.sql
@@repertoire/fils2.sql
?
wondersonic est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2008, 09h29   #3
Rédacteur/Modérateur
 
Avatar de orafrance
 
Inscription : janvier 2004
Messages : 15 861
Détails du profil
Informations personnelles :
Âge : 35

Informations forums :
Inscription : janvier 2004
Messages : 15 861
Points : 16 212
Points : 16 212
il me semble qu'il manque le chemin complet... les chemins relatifs en crontab c'est pas terrible
orafrance est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2008, 17h58   #4
Membre expérimenté

 
Inscription : décembre 2003
Messages : 480
Détails du profil
Informations forums :
Inscription : décembre 2003
Messages : 480
Points : 539
Points : 539
effectivement, si un script fonctionne dans ton environnement et pas via le crontab, c'est que l'environnement n'est pas conforme (profile, variable d'environnement)
__________________

*** OPN Exadata Specialist ***
*** OCE Performance Tuning 11g ***
*** OCE Rac 10g ***
*** OCP DBA 9i-10g-11g ***
Marc Musette est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 19/02/2008, 10h55   #5
Membre du Club
 
Inscription : juin 2006
Messages : 206
Détails du profil
Informations forums :
Inscription : juin 2006
Messages : 206
Points : 47
Points : 47
Merci, effectivement, dans l'environnement d'un cron, il n'y a pas beaucoup de variable definie, il faut donc les définir au début du script à executer
crazykangourou est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 18h04.


 
 
 
 
Partenaires

Hébergement Web