Fonctions d’agrégation : max
S’applique à :SQL Server
Retourne à partir d’une séquence de valeurs atomiques, $arg, l’élément dont la valeur est supérieure à celle de tous les autres.
Syntaxe
fn:max($arg as xdt:anyAtomicType*) as xdt:anyAtomicType?
Arguments
$arg
Séquence de valeurs atomiques à partir de laquelle la valeur maximale est renvoyée.
Remarques
Tous les types de valeurs atomisées passées à max() doivent être des sous-types du même type de base. Les types de base acceptés sont les types qui prennent en charge l’opération gt . Ces types incluent les trois types numériques de base intégrés, les types de base date/heure et les types xs:string (chaîne), xs:boolean (booléen) et xdt:untypedAtomic (atomique non typé). Les valeurs de type xdt:untypedAtomic sont converties en xs:double. S’il existe un mélange de ces types, ou si d’autres valeurs d’autres types sont passées, une erreur statique est générée.
Le résultat de max() reçoit le type de base du passé dans les types, tels que xs:double dans le cas de xdt:untypedAtomic. Si l'entrée est vide (valeur empty) de façon statique, « empty » est alors implicite et une erreur statique est émise.
La fonction max() retourne la valeur de la séquence supérieure à toute autre valeur de la séquence d’entrée. Pour les valeurs xs:string, le classement par défaut des points de code Unicode est utilisé. Si une valeur xdt:untypedAtomic ne peut pas être convertie en xs:double, la valeur est ignorée dans la séquence d’entrée , $arg. Si l'entrée est une séquence vide calculée de manière dynamique, la séquence vide est renvoyée.
Exemples
Cette rubrique fournit des exemples XQuery sur des instances XML stockées dans différentes colonnes de type xml dans la AdventureWorks2022
base de données.
R. Utilisation de la fonction XQuery max() pour localiser les postes de travail du processus de fabrication enregistrant le plus d'heures de main-d'œuvre
La requête fournie dans la fonction min (XQuery) peut être réécrite pour utiliser la fonction max().
Limites de mise en œuvre
Les limitations suivantes s'appliquent :
La fonction max() mappe tous les entiers à xs:decimal.
La fonction max() sur les valeurs de type xs:duration n’est pas prise en charge.
Les séquences faisant intervenir plusieurs types dérivés de différents types de base ne sont pas prises en charge.
L'option syntaxique fournissant un classement n'est pas prise en charge.