PL / SQL - Tanggal & Waktu

Pada bab ini, kita akan membahas Tanggal dan Waktu di PL / SQL. Ada dua kelas tipe data terkait tanggal dan waktu di PL / SQL -

  • Tipe data datetime
  • Tipe data interval

Tipe data Datetime adalah -

  • DATE
  • TIMESTAMP
  • TIMESTAMP DENGAN ZONA WAKTU
  • TIMESTAMP DENGAN ZONA WAKTU LOKAL

Tipe data Interval adalah -

  • INTERVAL TAHUN KE BULAN
  • INTERVAL HARI KE KEDUA

Nilai Bidang untuk Tipe Data Waktu dan Interval

Kedua datetime dan interval tipe data terdiri dari fields. Nilai dari bidang ini menentukan nilai tipe data. Tabel berikut mencantumkan bidang dan kemungkinan nilainya untuk waktu tanggal dan interval.

Nama Bidang Nilai Tanggal Waktu yang Valid Nilai Interval yang Valid
TAHUN -4712 hingga 9999 (tidak termasuk tahun 0) Semua bilangan bulat bukan nol
BULAN 01 sampai 12 0 sampai 11
HARI 01 hingga 31 (dibatasi oleh nilai MONTH dan YEAR, sesuai dengan aturan kalender untuk lokal) Semua bilangan bulat bukan nol
JAM 00 sampai 23 0 sampai 23
MENIT 00 sampai 59 0 hingga 59
KEDUA

00 hingga 59,9 (n), di mana 9 (n) adalah ketepatan waktu pecahan detik

Bagian 9 (n) tidak berlaku untuk DATE.

0 hingga 59,9 (n), di mana 9 (n) adalah ketepatan dari detik pecahan interval
TIMEZONE_HOUR

-12 hingga 14 (kisaran mengakomodasi perubahan waktu musim panas)

Tidak berlaku untuk DATE atau TIMESTAMP.

Tak dapat diterapkan
TIMEZONE_MINUTE

00 sampai 59

Tidak berlaku untuk DATE atau TIMESTAMP.

Tak dapat diterapkan
TIMEZONE_REGION Tidak berlaku untuk DATE atau TIMESTAMP. Tak dapat diterapkan
TIMEZONE_ABBR Tidak berlaku untuk DATE atau TIMESTAMP. Tak dapat diterapkan

Jenis dan Fungsi Data Waktu

Berikut adalah tipe data Datetime -

TANGGAL

Ini menyimpan informasi tanggal dan waktu dalam tipe data karakter dan angka. Itu terbuat dari informasi tentang abad, tahun, bulan, tanggal, jam, menit, dan detik. Ini ditentukan sebagai -

TIMESTAMP

Ini adalah perpanjangan dari tipe data DATE. Ini menyimpan tahun, bulan, dan hari dari tipe data DATE, bersama dengan nilai jam, menit, dan detik. Berguna untuk menyimpan nilai waktu yang tepat.

TIMESTAMP DENGAN ZONA WAKTU

Ini adalah varian dari TIMESTAMP yang menyertakan nama wilayah zona waktu atau perbedaan zona waktu dalam nilainya. Pengimbangan zona waktu adalah perbedaan (dalam jam dan menit) antara waktu lokal dan UTC. Tipe data ini berguna untuk mengumpulkan dan mengevaluasi informasi tanggal di seluruh wilayah geografis.

TIMESTAMP DENGAN ZONA WAKTU LOKAL

Ini adalah varian lain dari TIMESTAMP yang menyertakan perbedaan zona waktu dalam nilainya.

Tabel berikut menyediakan fungsi Datetime (di mana, x memiliki nilai datetime) -

S.No Nama & Deskripsi Fungsi
1

ADD_MONTHS(x, y);

Menambahkan y bulan untuk x.

2

LAST_DAY(x);

Menampilkan hari terakhir setiap bulan.

3

MONTHS_BETWEEN(x, y);

Mengembalikan jumlah bulan antara x dan y.

4

NEXT_DAY(x, day);

Mengembalikan tanggal waktu hari berikutnya setelahnyax.

5

NEW_TIME;

Mengembalikan nilai waktu / hari dari zona waktu yang ditentukan oleh pengguna.

6

ROUND(x [, unit]);

Putaran x.

7

SYSDATE();

Mengembalikan tanggal waktu saat ini.

8

TRUNC(x [, unit]);

Pemotongan x.

Fungsi timestamp (di mana, x memiliki nilai timestamp) -

S.No Nama & Deskripsi Fungsi
1

CURRENT_TIMESTAMP();

Mengembalikan TIMESTAMP DENGAN ZONA WAKTU yang berisi waktu sesi saat ini bersama dengan zona waktu sesi.

2

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

Mengekstrak dan mengembalikan tahun, bulan, hari, jam, menit, detik, atau zona waktu dari x.

3

FROM_TZ(x, time_zone);

Mengonversi TIMESTAMP x dan zona waktu yang ditentukan oleh zona_waktu menjadi TIMESTAMP DENGAN TIMEZONE.

4

LOCALTIMESTAMP();

Mengembalikan TIMESTAMP yang berisi waktu lokal di zona waktu sesi.

5

SYSTIMESTAMP();

Mengembalikan TIMESTAMP DENGAN ZONA WAKTU yang berisi waktu database saat ini bersama dengan zona waktu database.

6

SYS_EXTRACT_UTC(x);

Mengubah TIMESTAMP WITH TIMEZONE x menjadi TIMESTAMP yang berisi tanggal dan waktu dalam UTC.

7

TO_TIMESTAMP(x, [format]);

Mengonversi string x menjadi TIMESTAMP.

8

TO_TIMESTAMP_TZ(x, [format]);

Mengonversi string x menjadi TIMESTAMP WITH TIMEZONE.

Contoh

Potongan kode berikut menggambarkan penggunaan fungsi di atas -

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

Jenis dan Fungsi Data Interval

Berikut adalah tipe data Interval -

  • IINTERVAL YEAR TO MONTH - Ini menyimpan periode waktu menggunakan bidang datetime YEAR dan MONTH.

  • INTERVAL HARI KE KEDUA - Ini menyimpan periode waktu dalam hal hari, jam, menit, dan detik.

Fungsi Interval

S.No Nama & Deskripsi Fungsi
1

NUMTODSINTERVAL(x, interval_unit);

Mengonversi angka x menjadi INTERVAL DAY TO SECOND.

2

NUMTOYMINTERVAL(x, interval_unit);

Mengonversi angka x menjadi INTERVAL YEAR TO MONTH.

3

TO_DSINTERVAL(x);

Mengonversi string x menjadi INTERVAL DAY TO SECOND.

4

TO_YMINTERVAL(x);

Mengonversi string x menjadi INTERVAL YEAR TO MONTH.