PL / SQL - วันที่และเวลา

ในบทนี้เราจะพูดถึงวันที่และเวลาใน PL / SQL ประเภทข้อมูลที่เกี่ยวข้องกับวันที่และเวลามีสองประเภทใน PL / SQL -

  • ชนิดข้อมูลวันที่และเวลา
  • ประเภทข้อมูลช่วงเวลา

ชนิดข้อมูล Datetime คือ -

  • DATE
  • TIMESTAMP
  • จับเวลาด้วยโซนเวลา
  • จับเวลาด้วยโซนเวลาท้องถิ่น

ประเภทข้อมูลช่วงเวลาคือ -

  • ช่วงปีต่อเดือน
  • ช่วงเวลาระหว่างวันถึงวินาที

ค่าฟิลด์สำหรับชนิดข้อมูลวันที่เวลาและช่วงเวลา

ทั้งสอง datetime และ interval ประเภทข้อมูลประกอบด้วย fields. ค่าของฟิลด์เหล่านี้กำหนดมูลค่าของชนิดข้อมูล ตารางต่อไปนี้แสดงรายการฟิลด์และค่าที่เป็นไปได้สำหรับวันที่และช่วงเวลา

ชื่อฟิลด์ ค่า Datetime ที่ถูกต้อง ค่าช่วงเวลาที่ถูกต้อง
ปี -4712 ถึง 9999 (ไม่รวมปี 0) จำนวนเต็มที่ไม่ใช่ศูนย์
เดือน 01 ถึง 12 0 ถึง 11
วัน 01 ถึง 31 (จำกัด โดยค่าของ MONTH และ YEAR ตามกฎของปฏิทินสำหรับภาษา) จำนวนเต็มที่ไม่ใช่ศูนย์
ชั่วโมง 00 ถึง 23 0 ถึง 23
นาที 00 ถึง 59 0 ถึง 59
วินาที

00 ถึง 59.9 (n) โดยที่ 9 (n) คือความแม่นยำของเวลาเศษส่วนของวินาที

ส่วน 9 (n) ใช้ไม่ได้สำหรับ DATE

0 ถึง 59.9 (n) โดยที่ 9 (n) คือความแม่นยำของช่วงเศษส่วนของวินาที
TIMEZONE_HOUR

-12 ถึง 14 (ช่วงรองรับการเปลี่ยนแปลงเวลาออมแสง)

ไม่สามารถใช้ได้กับ DATE หรือ TIMESTAMP

ไม่สามารถใช้ได้
TIMEZONE_MINUTE

00 ถึง 59

ไม่สามารถใช้ได้กับ DATE หรือ TIMESTAMP

ไม่สามารถใช้ได้
TIMEZONE_REGION ไม่สามารถใช้ได้กับ DATE หรือ TIMESTAMP ไม่สามารถใช้ได้
TIMEZONE_ABBR ไม่สามารถใช้ได้กับ DATE หรือ TIMESTAMP ไม่สามารถใช้ได้

ประเภทข้อมูลและฟังก์ชันวันที่และเวลา

ต่อไปนี้เป็นชนิดข้อมูล Datetime -

วันที่

จัดเก็บข้อมูลวันที่และเวลาทั้งในประเภทข้อมูลตัวอักษรและตัวเลข มันทำจากข้อมูลศตวรรษปีเดือนวันที่ชั่วโมงนาทีและวินาที ระบุเป็น -

TIMESTAMP

เป็นส่วนขยายของประเภทข้อมูล DATE โดยจะจัดเก็บปีเดือนและวันของประเภทข้อมูล DATE พร้อมกับค่าชั่วโมงนาทีและวินาที มีประโยชน์สำหรับการจัดเก็บค่าเวลาที่แม่นยำ

จับเวลาด้วยโซนเวลา

เป็นตัวแปรของ TIMESTAMP ที่มีชื่อเขตเวลาหรือเขตเวลาออฟเซ็ตในค่า การชดเชยโซนเวลาคือความแตกต่าง (เป็นชั่วโมงและนาที) ระหว่างเวลาท้องถิ่นและ UTC ประเภทข้อมูลนี้มีประโยชน์สำหรับการรวบรวมและประเมินข้อมูลวันที่ในภูมิภาคทางภูมิศาสตร์

จับเวลาด้วยโซนเวลาท้องถิ่น

เป็นอีกตัวแปรหนึ่งของ TIMESTAMP ที่มีการชดเชยโซนเวลาในค่า

ตารางต่อไปนี้จัดเตรียมฟังก์ชัน Datetime (โดยที่ x มีค่าวันที่และเวลา) -

ส. เลขที่ ชื่อฟังก์ชันและคำอธิบาย
1

ADD_MONTHS(x, y);

เพิ่ม y เดือนถึง x.

2

LAST_DAY(x);

ส่งคืนวันสุดท้ายของเดือน

3

MONTHS_BETWEEN(x, y);

ส่งกลับจำนวนเดือนระหว่าง x และ y.

4

NEXT_DAY(x, day);

ส่งคืนวันที่และเวลาของวันถัดไปหลังจากนั้นx.

5

NEW_TIME;

ส่งคืนค่าเวลา / วันจากเขตเวลาที่ผู้ใช้ระบุ

6

ROUND(x [, unit]);

รอบ x.

7

SYSDATE();

ส่งคืนวันที่และเวลาปัจจุบัน

8

TRUNC(x [, unit]);

ตัดทอน x.

ฟังก์ชันการประทับเวลา (โดยที่ x มีค่าการประทับเวลา) -

ส. เลขที่ ชื่อฟังก์ชันและคำอธิบาย
1

CURRENT_TIMESTAMP();

ส่งคืน TIMESTAMP พร้อม TIME ZONE ที่มีเวลาเซสชันปัจจุบันพร้อมกับโซนเวลาเซสชัน

2

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

แยกและส่งคืนปีเดือนวันชั่วโมงนาทีวินาทีหรือเขตเวลาจาก x.

3

FROM_TZ(x, time_zone);

แปลง TIMESTAMP x และเขตเวลาที่ระบุโดย time_zone เป็น TIMESTAMP WITH TIMEZONE

4

LOCALTIMESTAMP();

ส่งคืน TIMESTAMP ที่มีเวลาท้องถิ่นในโซนเวลาของเซสชัน

5

SYSTIMESTAMP();

ส่งคืน TIMESTAMP พร้อม TIME ZONE ที่มีเวลาฐานข้อมูลปัจจุบันพร้อมกับโซนเวลาฐานข้อมูล

6

SYS_EXTRACT_UTC(x);

แปลง TIMESTAMP ด้วย TIMEZONE x เป็น TIMESTAMP ที่มีวันที่และเวลาเป็น UTC

7

TO_TIMESTAMP(x, [format]);

แปลงสตริง x เป็น TIMESTAMP

8

TO_TIMESTAMP_TZ(x, [format]);

แปลงสตริง x เป็น TIMESTAMP ด้วย TIMEZONE

ตัวอย่าง

ข้อมูลโค้ดต่อไปนี้แสดงให้เห็นถึงการใช้ฟังก์ชันข้างต้น -

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

ประเภทและฟังก์ชั่นข้อมูลช่วงเวลา

ต่อไปนี้เป็นประเภทข้อมูลช่วงเวลา -

  • IINTERVAL YEAR TO MONTH - เก็บช่วงเวลาหนึ่งโดยใช้ฟิลด์ YEAR และ MONTH datetime

  • ช่วงเวลาระหว่างวันถึงวินาที - จัดเก็บช่วงเวลาในรูปแบบของวันชั่วโมงนาทีและวินาที

ฟังก์ชันช่วงเวลา

ส. เลขที่ ชื่อฟังก์ชันและคำอธิบาย
1

NUMTODSINTERVAL(x, interval_unit);

แปลงจำนวน x เป็นช่วงเวลาระหว่างวันเป็นวินาที

2

NUMTOYMINTERVAL(x, interval_unit);

แปลงตัวเลข x เป็น INTERVAL YEAR TO MONTH

3

TO_DSINTERVAL(x);

แปลงสตริง x เป็นช่วงเวลาระหว่างวันถึงวินาที

4

TO_YMINTERVAL(x);

แปลงสตริง x เป็น INTERVAL YEAR TO MONTH