SQWareProduction:mssql:bin:sqwmsq RebuildIndexDatabase.ksh : Différence entre versions
m (Updated by BatchUser) |
m (Updated by BatchUser) |
||
Ligne 9 : | Ligne 9 : | ||
| | | | ||
<pre> | <pre> | ||
− | Begining : 2020- | + | Begining : 2020-12-15 21:15:15 |
− | End : 2020- | + | End : 2020-12-15 21:15:15 |
Duration : 00:00:00 | Duration : 00:00:00 | ||
</pre> | </pre> |
Version du 15 décembre 2020 à 21:16
Sommaire
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).
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-12-15 21:15:15 End : 2020-12-15 21:15:15 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).
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).
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