PL / SQL - Date et heure

Dans ce chapitre, nous discuterons de la date et de l'heure en PL / SQL. Il existe deux classes de types de données liés à la date et à l'heure dans PL / SQL -

  • Types de données Datetime
  • Types de données d'intervalle

Les types de données Datetime sont -

  • DATE
  • TIMESTAMP
  • HORAIRE AVEC FUSEAU HORAIRE
  • HORAIRE AVEC FUSEAU HORAIRE LOCAL

Les types de données Intervalle sont -

  • INTERVALLE ANNÉE AU MOIS
  • INTERVALLE JOUR À DEUXIÈME

Valeurs de champ pour les types de données Datetime et Interval

Tous les deux datetime et interval les types de données se composent de fields. Les valeurs de ces champs déterminent la valeur du type de données. Le tableau suivant répertorie les champs et leurs valeurs possibles pour les dates-heures et les intervalles.

Nom de domaine Valeurs Datetime valides Valeurs d'intervalle valides
AN -4712 à 9999 (hors année 0) Tout entier différent de zéro
MOIS 01 à 12 0 à 11
JOURNÉE 01 à 31 (limité par les valeurs de MONTH et YEAR, selon les règles du calendrier pour les paramètres régionaux) Tout entier différent de zéro
HEURE 00 à 23 0 à 23
MINUTE 00 à 59 0 à 59
SECONDE

00 à 59,9 (n), où 9 (n) est la précision des fractions de seconde

La partie 9 (n) n'est pas applicable pour DATE.

0 à 59,9 (n), où 9 (n) est la précision des fractions de seconde d'intervalle
TIMEZONE_HOUR

-12 à 14 (la plage s'adapte aux changements d'heure d'été)

Non applicable pour DATE ou TIMESTAMP.

N'est pas applicable
TIMEZONE_MINUTE

00 à 59

Non applicable pour DATE ou TIMESTAMP.

N'est pas applicable
TIMEZONE_REGION Non applicable pour DATE ou TIMESTAMP. N'est pas applicable
TIMEZONE_ABBR Non applicable pour DATE ou TIMESTAMP. N'est pas applicable

Les types et fonctions de données Datetime

Voici les types de données Datetime -

DATE

Il stocke les informations de date et d'heure dans les types de données caractère et numérique. Il est composé d'informations sur le siècle, l'année, le mois, la date, l'heure, les minutes et les secondes. Il est spécifié comme -

HORAIRE

C'est une extension du type de données DATE. Il stocke l'année, le mois et le jour du type de données DATE, ainsi que les valeurs d'heure, de minute et de seconde. Il est utile pour stocker des valeurs de temps précises.

HORAIRE AVEC FUSEAU HORAIRE

Il s'agit d'une variante de TIMESTAMP qui inclut un nom de région de fuseau horaire ou un décalage de fuseau horaire dans sa valeur. Le décalage du fuseau horaire est la différence (en heures et minutes) entre l'heure locale et UTC. Ce type de données est utile pour collecter et évaluer les informations de date dans les régions géographiques.

HORAIRE AVEC FUSEAU HORAIRE LOCAL

C'est une autre variante de TIMESTAMP qui inclut un décalage de fuseau horaire dans sa valeur.

Le tableau suivant fournit les fonctions Datetime (où, x a la valeur datetime) -

S. Non Nom de la fonction et description
1

ADD_MONTHS(x, y);

Ajoute y mois à x.

2

LAST_DAY(x);

Renvoie le dernier jour du mois.

3

MONTHS_BETWEEN(x, y);

Renvoie le nombre de mois entre x et y.

4

NEXT_DAY(x, day);

Renvoie la date et l' heure du jour suivant aprèsx.

5

NEW_TIME;

Renvoie la valeur heure / jour d'un fuseau horaire spécifié par l'utilisateur.

6

ROUND(x [, unit]);

Les manches x.

sept

SYSDATE();

Renvoie la date / heure actuelle.

8

TRUNC(x [, unit]);

Tronque x.

Fonctions d'horodatage (où, x a une valeur d'horodatage) -

S. Non Nom de la fonction et description
1

CURRENT_TIMESTAMP();

Renvoie un TIMESTAMP WITH TIME ZONE contenant l'heure actuelle de la session ainsi que le fuseau horaire de la session.

2

EXTRACT({ YEAR | MONTH | DAY | HOUR | MINUTE | SECOND } | { TIMEZONE_HOUR | TIMEZONE_MINUTE } | { TIMEZONE_REGION | } TIMEZONE_ABBR ) FROM x)

Extrait et renvoie une année, un mois, un jour, une heure, une minute, une seconde ou un fuseau horaire de x.

3

FROM_TZ(x, time_zone);

Convertit TIMESTAMP x et le fuseau horaire spécifié par time_zone en TIMESTAMP WITH TIMEZONE.

4

LOCALTIMESTAMP();

Renvoie un TIMESTAMP contenant l'heure locale dans le fuseau horaire de la session.

5

SYSTIMESTAMP();

Renvoie un TIMESTAMP WITH TIME ZONE contenant l'heure actuelle de la base de données ainsi que le fuseau horaire de la base de données.

6

SYS_EXTRACT_UTC(x);

Convertit TIMESTAMP WITH TIMEZONE x en un TIMESTAMP contenant la date et l'heure en UTC.

sept

TO_TIMESTAMP(x, [format]);

Convertit la chaîne x en TIMESTAMP.

8

TO_TIMESTAMP_TZ(x, [format]);

Convertit la chaîne x en TIMESTAMP WITH TIMEZONE.

Exemples

Les extraits de code suivants illustrent l'utilisation des fonctions ci-dessus -

Example 1

SELECT SYSDATE FROM DUAL;

Output -

08/31/2012 5:25:34 PM

Example 2

SELECT TO_CHAR(CURRENT_DATE, 'DD-MM-YYYY HH:MI:SS') FROM DUAL;

Output -

31-08-2012 05:26:14

Example 3

SELECT ADD_MONTHS(SYSDATE, 5) FROM DUAL;

Output -

01/31/2013 5:26:31 PM

Example 4

SELECT LOCALTIMESTAMP FROM DUAL;

Output -

8/31/2012 5:26:55.347000 PM

Les types et fonctions de données d'intervalle

Voici les types de données d'intervalle -

  • IINTERVAL DE L'ANNÉE AU MOIS - Il stocke une période de temps en utilisant les champs datetime YEAR et MONTH.

  • INTERVALLE JOUR À SECONDE - Il stocke une période de temps en termes de jours, heures, minutes et secondes.

Fonctions d'intervalle

S. Non Nom de la fonction et description
1

NUMTODSINTERVAL(x, interval_unit);

Convertit le nombre x en INTERVALLE DAY TO SECOND.

2

NUMTOYMINTERVAL(x, interval_unit);

Convertit le nombre x en INTERVALLE ANNÉE EN MOIS.

3

TO_DSINTERVAL(x);

Convertit la chaîne x en INTERVAL DAY TO SECOND.

4

TO_YMINTERVAL(x);

Convertit la chaîne x en INTERVAL YEAR TO MONTH.