> ## Documentation Index
> Fetch the complete documentation index at: https://private-7c7dfe99-mintlify-8c05c8a2.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

> Calcule le quantile d'une séquence de données numériques avec la précision déterminée.

# quantileTiming

<div id="quantileTiming">
  ## quantileTiming
</div>

Introduit dans : v1.1.0

Calcule, avec la précision déterminée, le [quantile](https://en.wikipedia.org/wiki/Quantile) d’une séquence de données numériques.

Le résultat est déterministe (il ne dépend pas de l’ordre de traitement de la requête).
La fonction est optimisée pour traiter des séquences décrivant des distributions, comme les temps de chargement des pages web ou les temps de réponse du backend.

Lors de l’utilisation de plusieurs fonctions `quantile*` avec des niveaux différents dans une requête, les états internes ne sont pas combinés (autrement dit, la requête est moins efficace qu’elle pourrait l’être).
Dans ce cas, utilisez la fonction [`quantiles`](/fr/reference/functions/aggregate-functions/quantiles#quantiles).

**Précision**

Le calcul est précis si :

* Le nombre total de valeurs ne dépasse pas 5670.
* Le nombre total de valeurs dépasse 5670, mais le temps de chargement de la page est inférieur à 1024ms.

Sinon, le résultat du calcul est arrondi au multiple de 16 ms le plus proche.

<Note>
  Pour calculer les quantiles du temps de chargement des pages, cette fonction est plus efficace et plus précise que [`quantile`](/fr/reference/functions/aggregate-functions/quantile).
</Note>

<Note>
  Si aucune valeur n’est fournie à la fonction (lors de l’utilisation de `quantileTimingIf`), [NaN](/fr/reference/data-types/float#nan-and-inf) est renvoyé. Cela permet de distinguer ces cas de ceux qui aboutissent à zéro. Voir la [clause ORDER BY](/fr/reference/statements/select/order-by) pour des remarques sur le tri des valeurs `NaN`.
</Note>

**Syntaxe**

```sql theme={null}
quantileTiming(level)(expr)
```

**Alias** : `medianTiming`

**Paramètres**

* `level` — Facultatif. Niveau du quantile. Nombre à virgule flottante constant compris entre 0 et 1. Nous recommandons d'utiliser une valeur `level` dans l'intervalle `[0.01, 0.99]`. Valeur par défaut : 0.5. À `level=0.5`, la fonction calcule la médiane. [`Float*`](/fr/reference/data-types/float)

**Arguments**

* `expr` — Expression sur des valeurs de colonne qui renvoie un nombre de type Float\*. Si des valeurs négatives sont transmises à la fonction, le comportement est indéfini. Si la valeur est supérieure à 30 000 (un temps de chargement de page de plus de 30 secondes), elle est considérée comme égale à 30 000. [`Float*`](/fr/reference/data-types/float)

**Valeur renvoyée**

Quantile au niveau spécifié. Si aucune valeur n'est transmise à la fonction (lors de l'utilisation de `quantileTimingIf`), NaN est renvoyé. Cela permet de distinguer ces cas de ceux qui produisent zéro. [`Float32`](/fr/reference/data-types/float)

**Exemples**

**Calcul du quantile de durée**

```sql title=Query theme={null}
CREATE TABLE t (response_time UInt32) ENGINE = Memory;
INSERT INTO t VALUES (72), (112), (126), (145), (104), (242), (313), (168), (108);

SELECT quantileTiming(response_time) FROM t;
```

```response title=Response theme={null}
┌─quantileTiming(response_time)─┐
│                           126 │
└───────────────────────────────┘
```

**Voir aussi**

* [median](/fr/reference/functions/aggregate-functions/median)
* [quantiles](/fr/reference/functions/aggregate-functions/quantiles)
