INDEXPROPERTY (Transact-SQL)
Retourne la valeur de la propriété de l'index ou des statistiques nommés en fonction d'un numéro d'identification de table, d'un nom d'index ou de statistiques et d'un nom de propriété spécifiés. Retourne la valeur NULL pour les index XML.
S'applique à : SQL Server (SQL Server 2008 via la version actuelle, Base de données SQL Windows Azure (version initiale via la version actuelle. |
Conventions de syntaxe Transact-SQL
Syntaxe
INDEXPROPERTY ( object_ID , index_or_statistics_name , property )
Arguments
object_ID
Expression qui contient le numéro d'identification d'objet de la table ou de la vue indexée dont les informations de propriété d'index doivent être fournies. object_ID est de type int.index_or_statistics_name
Expression qui contient le nom de l'index ou des statistiques dont les informations de propriété doivent être retournées. index_or_statistics_name est de type nvarchar(128).property
Expression contenant le nom de la propriété de base de données à renvoyer. property est de type varchar(128) et peut prendre l'une des valeurs suivantes.Notes
Sauf indication contraire, la valeur NULL est retournée lorsque property n'est pas un nom de propriété valide, lorsque object_ID n'est pas un ID d'objet valide, lorsque object_ID est un type d'objet qui n'est pas pris en charge pour la propriété spécifiée ou lorsque l'appelant n'est pas autorisé à consulter les métadonnées de l'objet.
Propriété
Description
Valeur
IndexDepth
Profondeur de l'index
Nombre de niveaux d'index.
NULL = une entrée ou un index XML n'est pas valide.
IndexFillFactor
Valeur de facteur de remplissage utilisée lors de la création et de la dernière restauration de l'index.
Facteur de remplissage
IndexID
Identificateur d'index sur une table ou une vue indexée spécifiée
ID de l'index
IsAutoStatistics
Les statistiques ont été générées par l'option AUTO_CREATE_STATISTICS de ALTER DATABASE.
1 = True
0 = False ou index XML.
IsClustered
Index cluster
1 = True
0 = False ou index XML.
IsDisabled
L'index est désactivé.
1 = True
0 = False
NULL = Entrée non valide.
IsFulltextKey
L'index est la clé d'indexation sémantique et de texte intégral pour une table.
1 = True
0 = False ou index XML.
NULL = l'entrée n'est pas valide.
S'applique à : SQL Server 2008 et SQL Server 2014.
IsHypothetical
L'index est hypothétique et ne peut être utilisé directement comme un chemin d'accès aux données. Les index hypothétiques conservent des statistiques au niveau des colonnes et sont gérés et utilisés par l'Assistant Paramétrage du moteur de base de données.
1 = True
0 = False ou index XML
NULL = l'entrée n'est pas valide.
IsPadIndex
L'index spécifie l'espace à laisser ouvert sur chaque nœud intérieur.
1 = True
0 = False ou index XML.
S'applique à : SQL Server 2008 et SQL Server 2014.
IsPageLockDisallowed
Valeur de verrouillage de page définie par l'option ALLOW_PAGE_LOCKS de ALTER INDEX.
1 = le verrouillage des pages n'est pas autorisé.
0 = le verrouillage des pages est autorisé.
NULL = l'entrée n'est pas valide.
S'applique à : SQL Server 2008 et SQL Server 2014.
IsRowLockDisallowed
Valeur de verrouillage de ligne définie par l'option ALLOW_ROW_LOCKS de ALTER INDEX.
1 = le verrouillage des lignes n'est pas autorisé.
0 = le verrouillage des lignes est autorisé.
NULL = l'entrée n'est pas valide.
S'applique à : SQL Server 2008 et SQL Server 2014.
IsStatistics
index_or_statistics_name représente des statistiques créées par l'instruction CREATE STATISTICS ou par l'option AUTO_CREATE_STATISTICS de ALTER DATABASE.
1 = True
0 = False ou index XML.
IsUnique
L'index est unique.
1 = True
0 = False ou index XML.
IsColumnstore
L'index est un index columnstore optimisé en mémoire xVelocity.
1 = True
0 = False
S'applique à : SQL Server 2012 et SQL Server 2014.
Types de retours
int
Exceptions
Retourne la valeur NULL en cas d'erreur ou si un appelant n'est pas autorisé à afficher l'objet.
Un utilisateur peut voir uniquement les métadonnées des éléments sécurisables qui lui appartiennent ou pour lesquels il dispose d'une autorisation. Cela signifie que les fonctions intégrées générant des métadonnées, telles que INDEXPROPERTY, peuvent retourner la valeur NULL si l'utilisateur ne dispose d'aucune autorisation sur l'objet. Pour plus d'informations, consultez Configuration de la visibilité des métadonnées.
Exemples
L'exemple suivant retourne les valeurs des propriétés IsClustered, IndexDepth et IndexFillFactor de l'index PK_Employee_BusinessEntityID de la table Employee dans la base de données AdventureWorks2012.
SELECT
INDEXPROPERTY(OBJECT_ID('HumanResources.Employee'),
'PK_Employee_BusinessEntityID','IsClustered')AS [Is Clustered],
INDEXPROPERTY(OBJECT_ID('HumanResources.Employee'),
'PK_Employee_BusinessEntityID','IndexDepth') AS [Index Depth],
INDEXPROPERTY(OBJECT_ID('HumanResources.Employee'),
'PK_Employee_BusinessEntityID','IndexFillFactor') AS [Fill Factor];
Le jeu de résultats obtenu est le suivant :
Is Clustered Index Depth Fill Factor
------------ ----------- -----------
1 2 0
(1 row(s) affected)
Voir aussi
Référence
sys.index_columns (Transact-SQL)
sys.stats_columns (Transact-SQL)