SQWareProduction:sybase:bin:sqwsyb UpdtStatsDatabase.ksh

De WikiFr_dbSQWare
Aller à : navigation, rechercher

Presentation

Script $gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh :


update index statistics
utilise la commande 'update index Statistics $lvsqw_Owner.$lvsqw_Table'
calcule les statisques sur toutes les colonnes indexees
vous pouvez aussi forcer le delete avec 'delete Statistics $lvsqw_Owner.$lvsqw_Table'
calcule dynamiquement le sample pour mettre l'option 'with sampling=$lvsqw_SamplePct percent'



Aide en ligne

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

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

Utilisation: sqwsyb_UpdtStatsDatabase.ksh [-h] -I <dataserver> [+ options]

DESCRIPTION
   sqwsyb_UpdtStatsDatabase.ksh 'update index statistics table' pour toutes les tables
SUPPORT
   Sybase versions supportees: 15 <= v <= 16.0

PARAMETERS
     -I  dataserver     : Target dataserver.
     -D  database       : Database name.
OPTIONS
     -h  help           : Affichage de l'aide complete.
     -s                 : Affichage des exemples d'utilisation.
     -IT   listtables   : Liste des tables pour executer l'update statistics (par defaut toutes).
     -ET   listtables   : Liste des tables a exclude.
     -IL   likeclause   : Clause like pour generer la liste des tables (exemple: 'tbl%').
     -EL   likeclause   : Clause like pour exclure les tables (example: 'notbl%').
     -WCT  whereclause  : Clause where pour generer la liste des tables.
     -FSS  SampleSize   : Pour forcer 'sample size'.
     -Del               : Delete stats before compute.
     -NoMail            : Desactive l'envoi de mail sur erreur a pmexpdba@gmail.com (par defaut, envoi sur erreur).
     -FRT  return_code  : Valeur forcee du code retour sur erreur
     -Dist              : Pour connexion distante a la database (change $gvsqw_DbaUser to $gvsqw_DistDbaUser ).
     -Type type         : Type de statistiques 'default','index','table','all' (defaut index).
     -AddMail email     : Adresse Email a ajouter a 'pmexpdba@gmail.com'.
     -SendReport        : Envoi du rapport d'execution.
     -SizeMaxTable Size : Tables a prendre en compte <= $lvsqw_SizeMaxTable Mb (par defaut, 1000000 Mb).
     -MinPctChange pct  : Min pct change pour prendre en compte les tables (par defaut, datachange>=10).
     -Hashing           : Active hashing (when rowcount >= 1000000) when ASE version >= 15.7 ESD#2 or SP50 (par defaut, False).
     -NoHashing         : Desactive hashing.
     -HashSize  Size    : Minimum rowcount pour hashing (par defaut, 1000000).
     -Locale   locale   : Force la Locale d'affichage de l'aide (fr,en).
     -Exec              : Execute update statistics (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 'dataserver' parameter, Utilisation: sqwsyb_UpdtStatsDatabase.ksh [-h] -I <dataserver> [+ options]

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 'dataserver' 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.01 SQWareProduction for Sybase (dbSQWare) ... 

#Standard (Locale) help for script sqwsyb_UpdtStatsDatabase.ksh:


# XXXXX : -WCT
# XXXXX : -Hashing
# XXXXX : -HashSize
# XXXXX : -NoHashing
# XXXXX : -SizeMaxTable
# XXXXX : -MinPctChange

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

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -Locale fr -h
#Affichage de l'aide en ligne pour ce script avec forçage de la locale 'fr' (Locale par défaut gérée par la variable gvsqw_Locale)

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

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com'
#Ajoute la liste de mail à l'adresse par défaut gérée par la variable gvsqw_GlobalMail

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -SendReport
#Envoie la log par mail à la fin du traitement même s'il n'y a pas d'erreur

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -NoMail
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, send on error)

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -Type <Type> -Exec
#Execute les commandes generees et change le type de statistics ('default','index','table','all')

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName>
#Genere les commandes mais ne les execute pas !

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -FSS <SampleSize> -Exec
#pour forcer le sample size 'with sampling=<SampleSize> percent'
#par defaut, le script calcule dynamiquement le sample

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -Del -Exec
#delete statistics avant de les recalculer: 'delete statistics $lvsqw_Owner.$lvsqw_Table'

$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -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_sqwsyb_UpdtStatsDatabase=<NumericValue>
#dans le fichier de configuration $gvsqw_SybBin/../etc_cust/sqwsyb_GlobalVar.cfg

#Options pour generer la liste des tables avec filtres (vous pouvez tous les mixer):
$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -IT <listtbl>
#Genere la liste des tables avec 'in list':
#=> and name in ('$ListInclude')
$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -ET <listtbl> -Dist
#Genere la liste des tables avec 'not in list':
#=> and name not in ('$ListExclude')
$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -IL <likeclause>
#Genere la liste des tables avec 'like':
#=> and name like '$LikeClause'
$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -EL <likeclause>
#Genere la liste des tables avec 'not like':
#=> and name not like '$NotLikeClause'
$gvsqw_SybBin/sqwsyb_UpdtStatsDatabase.ksh -I $DSQUERY -D <DbName> -W <whereclause>
#Genere la liste des tables avec 'where clause':
#=> and '$WhereClause'

Information.png
Information:
Pour être sûr que les exemples sont exacts, reportez-vous directement à l'option d'aide en ligne du script -s .