SQWareProduction:sybase:bin:sqwsyb UpdtStatsDatabase.ksh
Sommaire
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).
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).
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).
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'