PL / SQL - Datum und Uhrzeit

In diesem Kapitel werden Datum und Uhrzeit in PL / SQL erläutert. In PL / SQL gibt es zwei Klassen von datums- und zeitbezogenen Datentypen:

  • Datetime-Datentypen
  • Intervalldatentypen

Die Datetime-Datentypen sind -

  • DATE
  • TIMESTAMP
  • Zeitstempel mit Zeitzone
  • Zeitstempel mit lokaler Zeitzone

Die Intervalldatentypen sind -

  • INTERVALLJAHR BIS MONAT
  • Intervalltag bis zum zweiten

Feldwerte für Datetime- und Intervalldatentypen

Beide datetime und interval Datentypen bestehen aus fields. Die Werte dieser Felder bestimmen den Wert des Datentyps. In der folgenden Tabelle sind die Felder und ihre möglichen Werte für Datenzeiten und Intervalle aufgeführt.

Feldname Gültige Datetime-Werte Gültige Intervallwerte
JAHR -4712 bis 9999 (ohne Jahr 0) Beliebige Ganzzahl ungleich Null
MONAT 01 bis 12 0 bis 11
TAG 01 bis 31 (begrenzt durch die Werte von MONAT und JAHR gemäß den Regeln des Kalenders für das Gebietsschema) Beliebige Ganzzahl ungleich Null
STUNDE 00 bis 23 0 bis 23
MINUTE 00 bis 59 0 bis 59
ZWEITE

00 bis 59,9 (n), wobei 9 (n) die Genauigkeit der Zeitbruchsekunden ist

Der 9 (n) Teil gilt nicht für DATE.

0 bis 59,9 (n), wobei 9 (n) die Genauigkeit der Intervallbruchsekunden ist
TIMEZONE_HOUR

-12 bis 14 (Bereich berücksichtigt Änderungen der Sommerzeit)

Gilt nicht für DATE oder TIMESTAMP.

Unzutreffend
TIMEZONE_MINUTE

00 bis 59

Gilt nicht für DATE oder TIMESTAMP.

Unzutreffend
TIMEZONE_REGION Gilt nicht für DATE oder TIMESTAMP. Unzutreffend
TIMEZONE_ABBR Gilt nicht für DATE oder TIMESTAMP. Unzutreffend

Die Datetime-Datentypen und -Funktionen

Im Folgenden sind die Datetime-Datentypen aufgeführt:

DATUM

Es speichert Datums- und Uhrzeitinformationen sowohl in Zeichen- als auch in Zahlendatentypen. Es besteht aus Informationen zu Jahrhundert, Jahr, Monat, Datum, Stunde, Minute und Sekunde. Es wird angegeben als -

TIMESTAMP

Es ist eine Erweiterung des Datentyps DATE. Es speichert das Jahr, den Monat und den Tag des Datentyps DATE sowie die Werte für Stunde, Minute und Sekunde. Es ist nützlich, um genaue Zeitwerte zu speichern.

Zeitstempel mit Zeitzone

Es handelt sich um eine Variante von TIMESTAMP, deren Wert einen Zeitzonenregionsnamen oder einen Zeitzonenversatz enthält. Der Zeitzonenversatz ist die Differenz (in Stunden und Minuten) zwischen Ortszeit und UTC. Dieser Datentyp ist nützlich zum Sammeln und Auswerten von Datumsinformationen in verschiedenen geografischen Regionen.

Zeitstempel mit lokaler Zeitzone

Es ist eine andere Variante von TIMESTAMP, deren Wert einen Zeitzonenversatz enthält.

Die folgende Tabelle enthält die Datetime-Funktionen (wobei x den Datetime-Wert hat) -

S.No. Funktionsname & Beschreibung
1

ADD_MONTHS(x, y);

Fügt hinzu y Monate bis x.

2

LAST_DAY(x);

Gibt den letzten Tag des Monats zurück.

3

MONTHS_BETWEEN(x, y);

Gibt die Anzahl der Monate zwischen zurück x und y.

4

NEXT_DAY(x, day);

Gibt die Datums- und Uhrzeitangabe des nächsten Tages zurückx.

5

NEW_TIME;

Gibt den Zeit- / Tageswert aus einer vom Benutzer angegebenen Zeitzone zurück.

6

ROUND(x [, unit]);

Runden x.

7

SYSDATE();

Gibt die aktuelle Datum / Uhrzeit zurück.

8

TRUNC(x [, unit]);

Abschneidet x.

Zeitstempelfunktionen (wobei x einen Zeitstempelwert hat) -

S.No. Funktionsname & Beschreibung
1

CURRENT_TIMESTAMP();

Gibt einen TIMESTAMP WITH TIME ZONE zurück, der die aktuelle Sitzungszeit zusammen mit der Sitzungszeitzone enthält.

2

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

Extrahiert und gibt ein Jahr, einen Monat, einen Tag, eine Stunde, eine Minute, eine Sekunde oder eine Zeitzone aus zurück x.

3

FROM_TZ(x, time_zone);

Konvertiert den TIMESTAMP x und die durch time_zone angegebene Zeitzone in einen TIMESTAMP WITH TIMEZONE.

4

LOCALTIMESTAMP();

Gibt einen TIMESTAMP zurück, der die Ortszeit in der Sitzungszeitzone enthält.

5

SYSTIMESTAMP();

Gibt einen TIMESTAMP WITH TIME ZONE zurück, der die aktuelle Datenbankzeit zusammen mit der Datenbankzeitzone enthält.

6

SYS_EXTRACT_UTC(x);

Konvertiert den TIMESTAMP WITH TIMEZONE x in einen TIMESTAMP, der Datum und Uhrzeit in UTC enthält.

7

TO_TIMESTAMP(x, [format]);

Konvertiert den String x in einen TIMESTAMP.

8

TO_TIMESTAMP_TZ(x, [format]);

Konvertiert den String x in einen TIMESTAMP WITH TIMEZONE.

Beispiele

Die folgenden Codeausschnitte veranschaulichen die Verwendung der oben genannten Funktionen:

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

Die Intervalldatentypen und -funktionen

Im Folgenden sind die Intervalldatentypen aufgeführt:

  • IINTERVALES JAHR BIS MONAT - Speichert einen Zeitraum mithilfe der Datums- / Uhrzeitfelder JAHR und MONAT.

  • INTERVALLTAG ZUM ZWEITEN - Es wird ein Zeitraum in Tagen, Stunden, Minuten und Sekunden gespeichert.

Intervallfunktionen

S.No. Funktionsname & Beschreibung
1

NUMTODSINTERVAL(x, interval_unit);

Konvertiert die Zahl x in einen INTERVALLTAG IN ZWEITEN.

2

NUMTOYMINTERVAL(x, interval_unit);

Konvertiert die Zahl x in ein INTERVALLJAHR IN MONAT.

3

TO_DSINTERVAL(x);

Konvertiert die Zeichenfolge x in einen INTERVALLTAG IN ZWEITEN.

4

TO_YMINTERVAL(x);

Konvertiert die Zeichenfolge x in ein INTERVALLJAHR IN MONAT.