Catégories :

Fonctions de conversion

TRY_TO_TIME

Une version spéciale de TO_TIME , TIME qui effectue la même opération (c’est-à-dire convertit une expression d’entrée en heure), mais avec une prise en charge du traitement des erreurs (c’est-à-dire que si la conversion ne peut pas être effectuée, elle retourne une valeur NULL au lieu de produire une erreur).

Pour plus d’informations, voir Fonctions de conversion de traitement des erreurs.

Voir aussi :

TO_TIME , TIME

Syntaxe

TRY_TO_TIME( <string_expr> [, <format> ] )
TRY_TO_TIME( '<integer>' )
Copy

Arguments

Obligatoire :

Une des options :

string_expr

Chaîne pouvant être convertie en heure valide.

'integer'

Expression qui est évaluée sur (correspond à) une chaîne contenant un entier, par exemple '15000000'. Selon l’ampleur de la chaîne, elle peut être interprétée comme des secondes, des millisecondes, des microsecondes ou des nanosecondes. Pour plus de détails, voir les Notes sur l’utilisation.

Facultatif :

format

Spécificateur de format pour string_expr ou AUTO. Pour plus d’informations, voir Formats de date et d’heure dans les fonctions de conversion.

La valeur par défaut est la valeur actuelle du paramètre de session TIME_INPUT_FORMAT (AUTO par défaut).

Renvoie

Le type de données de la valeur renvoyée est TIME.

Notes sur l’utilisation

  • Le format d’affichage des heures dans la sortie est déterminé par le paramètre de session TIME_OUTPUT_FORMAT (par défaut, HH24:MI:SS).

  • Si le format du paramètre d’entrée est une chaîne contenant un entier, l’unité de mesure de la valeur (secondes, microsecondes, millisecondes ou nanosecondes) est déterminée comme suit :

    • Une fois la chaîne convertie en entier, l’entier est traité comme un nombre de secondes, millisecondes, microsecondes ou nanosecondes après le début de l’epoch Unix (1970-01-01 00:00:00.000000000 UTC).

      • Si l’entier est inférieur à 31536000000 (le nombre de millisecondes dans une année), alors la valeur est traitée comme un nombre de secondes.

      • Si la valeur est supérieure ou égale à 31536000000 et inférieure à 31536000000000, la valeur est alors traitée en millisecondes.

      • Si la valeur est supérieure ou égale à 31536000000000 et inférieure à 31536000000000000, la valeur est alors traitée en microsecondes.

      • Si la valeur est supérieure ou égale à 31536000000000000, alors la valeur est traitée comme des nanosecondes.

    • Si plusieurs lignes sont évaluées (par exemple, si l’entrée est le nom de colonne d’une table qui contient plus d’une ligne), chaque valeur est examinée indépendamment pour déterminer si elle représente des secondes, des millisecondes, des microsecondes ou des nanosecondes.

Exemples

Cet exemple utilise TRY_TO_TIME :

SELECT TRY_TO_TIME('12:30:00'), TRY_TO_TIME('Invalid');
Copy
+-------------------------+------------------------+
| TRY_TO_TIME('12:30:00') | TRY_TO_TIME('INVALID') |
|-------------------------+------------------------|
| 12:30:00                | NULL                   |
+-------------------------+------------------------+

Voir TO_TIME , TIME pour des exemples de conversion d’une expression d’entrée en heure.