SQWareProduction:mssql:bin:sqwmsq RebuildIndexDatabase.ksh

De WikiFr_dbSQWare
Révision datée du 29 novembre 2020 à 20:02 par BatchUser (discussion | contributions) (Updated by BatchUser)
Aller à : navigation, rechercher

Presentation

Script $gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh :


Rebuild les indexes de la database.
version = 2000 -> Dbcc dbreindex (N'[$lvsqw_Owner].[$lvsqw_TableName]',,90)
version >= 2005 -> alter index all on [$lvsqw_Owner].[$lvsqw_TableName] Rebuild avec (online = off)



Aide en ligne

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

Sourcing sqwmsq_Global.lib v2024.07 SQWareProduction for MsSql (dbSQWare) ... 

Utilisation: sqwmsq_RebuildIndexDatabase.ksh [-h] -I <FreeTdsAlias> -D <DatabaseName> [+ options]

DESCRIPTION
   sqwmsq_RebuildIndexDatabase.ksh Rebuild index of database
SUPPORT
   MsSql versions supportees: 2000 <= v <= 2022

PARAMETERS
     -I   Instance      : Instance cible (freeTds alias).
     -D   databasename  : Base de donnees cible.
OPTIONS
     -h                 : Affichage de l'aide complete.
     -s                 : Affichage des exemples d'utilisation.
     -IT   listtables   : Liste des tables sur lesquelles executer les statistiques de mises a jour (par defaut toutes).
     -ET   listtables   : Liste des tables a exclure.
     -IL   likeclause   : Clause Like pour generer la liste des tables (exemple: 'tbl%').
     -EL   likeclause   : Clause like pour exclure les tables (exemple: 'notbl%').
     -WCT  whereclause  : Clause where pour generer la liste des tables.
     -FRT       code    : Valeur forcee du code retour sur erreur.
     -AddMail   email   : Adresse Email a ajouter a 'pmexpdba@gmail.com'.
     -RebuildType  type : Type de reconstruction, 'all' pour table, 'index' pour indexes (par defaut 'index').
     -MinRatioReb ratio : Min avg_fragmentation_in_percent avant reconstruction (par defaut 30 %).
     -MinRatioRgz ratio : Min avg_fragmentation_in_percent avant reorganisation (par defaut 10 %).
     -SizeMaxIndex Size : Indexes a prendre en compte <= $gvsqw_SizeMaxIndexRebuild Mb (par defaut, 50000 Mb).
     -SizeMinIndex Size : Indexes a prendre en compte >= $gvsqw_SizeMinIndexRebuild Mb (par defaut, 1 Mb).
     -SendReport        : Envoi du rapport d'execution.
     -SortInTempdb      : Reconstruction avec option sort_in_tempdb=on.
     -Online            : Reconstruction avec option online=on.
     -Force             : Force Rebuild offline si necessaire quand -Online.
     -NoMail            : Desactive l'envoi de mail sur erreur a pmexpdba@gmail.com (par defaut, envoi sur erreur).
     -Locale    locale  : Force la Locale d'affichage de l'aide (fr,en).
     -Flag     filename : Fichier a chercher.
     -Exec              : Execute les commandes generees (par defaut, affiche les commandes generees).

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 'FreeTdsAlias' parameter, Utilisation: sqwmsq_RebuildIndexDatabase.ksh [-h] -I <FreeTdsAlias> -D <DatabaseName> [+ options]

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

Begining     : 2020-11-29 20:00:33
End          : 2020-11-29 20:00:33
Duration     : 00:00:00 

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_mssql : " (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_mssql : " (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 sqwmsq_Global.lib v2024.07 SQWareProduction for MsSql (dbSQWare) ... 

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


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

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

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

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName>
#Genere les commandes mais ne les execute pas !

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -Exec
#Rebuild les indexes de la database <DbName>

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -Force -Exec
#Force l'execution des commandes generees

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -Online -Exec
#Reconstruit les indexes sans poser de verrous sur les tables 

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -SortInTempdb -Exec
#Reconstruit l’index en utilisant la table tempdb pour stocker les resultats intermediaires du tri
#Reduit la duree de la reconstruction d'index, mais augmente la quantite d’espace disque temporaire utilise

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -RebuildType <type> -Exec
#Execute un rebuild de type 'all' pour les tables, 'index' pour les indexes (par defaut '$gvsqw_RebuildType')

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -MinRatioReb <ratio> -Exec
#Reorganise les indexes quand avg_fragmentation_in_percent vaut 10% (par defaut $gvsqw_MinRatioRgz %)

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -MinRatioRgz <ratio> -Exec
#Reconstruit les indexes quand avg_fragmentation_in_percent vaut 30% (par defaut $gvsqw_MinRatioReb %)

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -SizeMinIndex 100 -SizeMaxIndex 1000 -Exec
#Ne prend en compte que les indexes dont la taille est comprise entre 100 et 1000 Mb

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -IT 'TblName1,TblName2' -Exec
#Execute les commandes generees pour seulement les 2 tables specifiees

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -ET 'TblName3,TblName4' -Exec
#Execute les commandes generees sauf pour les 2 tables specifiees

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -IL '%_PROD' -Exec
#Clause like pour generee une liste dynamique de tables a inclure (exemple: 'dbprod%')

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -EL '%_TESTS' -Exec
#Clause like pour generee une liste dynamique de tables a exclure (exemple: 'dbtest%')

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -WCT '<condition>' -Exec
#Clause where pour generee une liste dynamique de tables a inclure (exemple: 'OPEN_MODE=MOUNTED')

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec
#Ajoute la liste de mail a l'adresse par defaut geree par $gvsqw_GlobalMail

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -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_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -D <DbName> -NoMail -Exec
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur)

$gvsqw_MsqBin/sqwmsq_RebuildIndexDatabase.ksh -I $Alias -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_sqwmsq_RebuildIndexDatabase=<NumericValue>
#dans le fichier de configuration $gvsqw_MsqBin/../etc_cust/sqwmsq_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 .