SQWareProduction:mysql:bin:sqwmys ExecSQL.ksh : Différence entre versions

De WikiFr_dbSQWare
Aller à : navigation, rechercher
m (Updated by BatchUser)
m (Updated by BatchUser)
 
(2 révisions intermédiaires par le même utilisateur non affichées)
(Aucune différence)

Version actuelle datée du 2 juillet 2021 à 15:38

Presentation

Script $gvsqw_MysBin/sqwmys_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_MysBin/sqwmys_ExecSQL.ksh -h
Contenu de l'aide :

Sourcing sqwmys_Global.lib v2024.07 SQWareProduction for MySQL (dbSQWare) ... 

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

DESCRIPTION
   sqwmys_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: sqwmys_ExecSQL.ksh [-h] -I <instance> [+ options]
For full help : sqwmys_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_mysql : " (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_mysql : " (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 sqwmys_Global.lib v2024.07 SQWareProduction for MySQL (dbSQWare) ... 

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

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

$gvsqw_Mys/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_Mys/sqwgen_ExecSQL.ksh -s
#Affichage des exemples d'utilisation pour ce script

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

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

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

$gvsqw_Mys/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_Mys/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_Mys/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_Mys/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_Mys/../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 .