SQWareProduction:sybase:bin:sqwsyb ExecSQL.ksh

De WikiFr_dbSQWare
Révision datée du 2 juillet 2021 à 15:38 par BatchUser (discussion | contributions) (Updated by BatchUser)
(diff) ← Version précédente | Voir la version actuelle (diff) | Version suivante → (diff)
Aller à : navigation, rechercher

Presentation

Script $gvsqw_SybBin/sqwsyb_ExecSQL.ksh :


execute un fichier SQL sur l'instance



Aide en ligne

L'aide en ligne est accessible dans la plupart des scripts avec l'option -h.
Ex: $gvsqw_SybBin/sqwsyb_ExecSQL.ksh -h
Contenu de l'aide :

Sourcing sqwsyb_Global.lib v2024.07 SQWareProduction for Sybase (dbSQWare) ... 

Usage: sqwsyb_ExecSQL.ksh [-h] -I <instance> [+ options]

DESCRIPTION
   sqwsyb_ExecSQL.ksh execute SQL file on instance
SUPPORT
   All rdbms type and version

PARAMETERS
     -I  instance       : Target instance.
     -F  FileName       : Filename to execute.
OPTIONS
     -h                 : Display the full usage.
     -s                 : Display samples of usage.
     -Opt  option       : Additional options for sql connection.
     -FRT       code    : Force return code value on error.
     -NoMail            : Deactivate sendmail on error pmexpdba@gmail.com (by default, send on error).
     -Locale    locale  : Force Locale for help display (fr,en).
     -AddMail   email   : Email address to add at 'pmexpdba@gmail.com'.
     -SendReport        : Send execution log report.
     -Dist              : For distant connection to database (change $gvsqw_ConnectString to $gvsqw_DistConnectString ).
     -Exec              : Run commands (by default, display generated commands).

Information.png
Information:
Pour etre sur d'avoir une aide a jour, reportez vous directement a l'aide en ligne du script avec l'option -h .


Traitement de l'erreur

Erreurs de parse des arguments

Ce type de message est genere:

Lack instance parameter, Usage: sqwsyb_ExecSQL.ksh [-h] -I <instance> [+ options]
For full help : sqwsyb_ExecSQL.ksh -h

Si vous vous connectez via un terminal, aucun mail ne sera envoyé et vous aurez plutôt ce type de message:

Not sending mail because you are in connected mode !!!
Lack instance parameter

Si vous n'êtes pas connecté à un terminal, le message d'erreur apparaît et est envoyé par mail à l'adresse contenue dans la variable $gvsqw_GlobalMail (Voir l'aide pour personnaliser cette variable). L'objet commence toujours par "$gvsqw_MailMsg_sybase : " (Voir l'aide pour personnaliser cette variable).

Information.png
Information:
L'envoi de mail peut être désactivé par l'option -NoMail pour une exécution.


Execution errors

Que vous soyez ou non connecté à un terminal, le message d'erreur apparaît et un mail contenant un résumé des erreurs de traitement est envoyé à l'adresse contenue dans la variable $gvsqw_GlobalMail (Voir l'aide pour personnaliser cette variable). L'objet commence toujours par "$gvsqw_MailMsg_sybase : " (Voir l'aide pour personnaliser cette variable).

Information.png
Information:
L'envoi de mail peut être désactivé par l'option -NoMail pour une exécution.


Exemples d'utilisation

Sourcing sqwsyb_Global.lib v2024.07 SQWareProduction for Sybase (dbSQWare) ... 

#Standard generic (Locale) help for script sqwsyb_ExecSQL.ksh:

$gvsqw_Syb/sqwgen_ExecSQL.ksh -h
#Affichage de l'aide en ligne pour ce script

$gvsqw_Syb/sqwgen_ExecSQL.ksh -Locale fr -h
#Affichage de l'aide en ligne pour ce script avec forcage de la locale 'fr' (Locale par defaut geree par la variable $gvsqw_Locale)

$gvsqw_Syb/sqwgen_ExecSQL.ksh -s
#Affichage des exemples d'utilisation pour ce script

$gvsqw_Syb/sqwgen_ExecSQL.ksh -I <Instance> -F <FileName>
#Affiche l'ensemble des commandes generees par le script sans les executer

$gvsqw_Syb/sqwgen_ExecSQL.ksh -I <Instance> -F <FileName> -Exec
#Execute le fichier SQL <FileName> sur l'instance <Instance>

$gvsqw_Syb/sqwgen_ExecSQL.ksh -I <Instance> -F <FileName> -Opt '<Option>' -Exec
#Execute le script avec le parametre SQL optionnel <Option>

$gvsqw_Syb/sqwgen_ExecSQL.ksh -I <Instance> -F <FileName> -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec
#Ajoute la liste de mail a l'adresse par defaut geree par la variable $gvsqw_GlobalMail (seulement cette fois)

$gvsqw_Syb/sqwgen_ExecSQL.ksh -I <Instance> -F <FileName> -SendReport -Exec
#Envoie la log par mail a la fin du traitement meme s'il n'y a pas d'erreur (par defaut, seulement en cas d'erreur)

$gvsqw_Syb/sqwgen_ExecSQL.ksh -I <Instance> -F <FileName> -NoMail -Exec
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur)

$gvsqw_Syb/sqwgen_ExecSQL.ksh -I <Instance> -F <FileName> -FRT <NumericValue> -Exec
#Force le code retour a '<NumericValue>' sur erreur (si pas d'erreur, "exit 0!")
#Vous pouvez aussi forcer le code retour de ce script pour tous
#si vous settez la variable d'environnement: $gvsqw_ForcedReturnCodeScript_sqwgen_ExecSQL=<NumericValue>
#dans le fichier de configuration $gvsqw_Syb/../etc_cust/sqwgen_GlobalVar.cfg
Information.png
Information:
Pour être sûr que les exemples sont exacts, reportez-vous directement à l'option d'aide en ligne du script -s .