Dans MariaDB, CURRENT_TIMESTAMP
et CURRENT_TIMESTAMP()
sont synonymes de NOW()
.
Le NOW()
est une fonction de date et d'heure intégrée qui renvoie la date et l'heure actuelles.
L'heure est renvoyée au format 'YYYY-MM-DD HH:MM:SS'
ou YYYYMMDDHHMMSS.uuuuuu
format, selon que la fonction est utilisée dans un contexte de chaîne ou numérique.
Syntaxe
CURRENT_TIMESTAMP()
peut être utilisé des manières suivantes :
CURRENT_TIMESTAMP
CURRENT_TIMESTAMP([precision])
Où precision
est la précision à la microseconde.
Vous pouvez également appeler NOW()
comme ceci :
NOW([precision])
Exemple
Voici un exemple :
SELECT
CURRENT_TIMESTAMP,
CURRENT_TIMESTAMP(),
NOW();
Résultat :
+---------------------+---------------------+---------------------+ | CURRENT_TIMESTAMP | CURRENT_TIMESTAMP() | NOW() | +---------------------+---------------------+---------------------+ | 2021-05-09 15:46:30 | 2021-05-09 15:46:30 | 2021-05-09 15:46:30 | +---------------------+---------------------+---------------------+
Nous pouvons voir que les trois renvoient le même résultat.
Contexte numérique
Lorsqu'il est utilisé dans un contexte numérique, l'heure résultante est en YYYYMMDDHHMMSS.uuuuuu
formater.
Exemple :
SELECT
CURRENT_TIMESTAMP,
CURRENT_TIMESTAMP + 0,
CURRENT_TIMESTAMP() + 0;
Résultat :
+---------------------+-----------------------+-------------------------+ | CURRENT_TIMESTAMP | CURRENT_TIMESTAMP + 0 | CURRENT_TIMESTAMP() + 0 | +---------------------+-----------------------+-------------------------+ | 2021-05-09 15:47:12 | 20210509154712 | 20210509154712 | +---------------------+-----------------------+-------------------------+
Précision
Lorsqu'il est utilisé avec le CURRENT_TIMESTAMP([precision])
syntaxe, vous pouvez spécifier la précision de la microseconde pour le résultat.
Exemple :
SELECT
CURRENT_TIMESTAMP(6),
CURRENT_TIMESTAMP(6) + 0;
Résultat :
+----------------------------+--------------------------+ | CURRENT_TIMESTAMP(6) | CURRENT_TIMESTAMP(6) + 0 | +----------------------------+--------------------------+ | 2021-05-09 15:47:39.508987 | 20210509154739.508987 | +----------------------------+--------------------------+
La valeur maximale pour la précision de la microseconde est de 6. Voici ce qui se passe lorsqu'un nombre plus élevé est passé pour la précision :
SELECT CURRENT_TIMESTAMP(7);
Résultat :
ERROR 1426 (42000): Too big precision 7 specified for 'current_timestamp'. Maximum is 6
Ajout à l'horodatage actuel
Il existe de nombreuses façons d'effectuer des opérations arithmétiques sur les valeurs datetime dans MariaDB.
Voici un exemple d'utilisation de l'opérateur d'addition (+
) pour ajouter 2 jours à la date :
SELECT
CURRENT_TIMESTAMP,
CURRENT_TIMESTAMP + INTERVAL 2 DAY;
Résultat :
+---------------------+------------------------------------+ | CURRENT_TIMESTAMP | CURRENT_TIMESTAMP + INTERVAL 2 DAY | +---------------------+------------------------------------+ | 2021-05-09 15:49:01 | 2021-05-11 15:49:01 | +---------------------+------------------------------------+
Voir aussi des fonctions comme DATE_ADD()
et ADDDATE()
pour une autre façon d'ajouter à la date actuelle.
Soustraction de la date actuelle
Voici un exemple d'utilisation de l'opérateur de soustraction (-
) pour soustraire 10 jours à la date actuelle :
SELECT
CURRENT_TIMESTAMP,
CURRENT_TIMESTAMP - INTERVAL 10 DAY;
Résultat :
+---------------------+-------------------------------------+ | CURRENT_TIMESTAMP | CURRENT_TIMESTAMP - INTERVAL 10 DAY | +---------------------+-------------------------------------+ | 2021-05-09 15:49:28 | 2021-04-29 15:49:28 | +---------------------+-------------------------------------+
Voir des fonctions comme DATE_SUB()
et SUBDATE()
pour une autre façon de soustraire de la date actuelle.