PostgreSQL - ฟังก์ชัน DATE / TIME และตัวดำเนินการ

เราได้พูดคุยกันเกี่ยวกับวันที่ / เวลาชนิดข้อมูลในบทที่ชนิดข้อมูล ตอนนี้ให้เราดูตัวดำเนินการวันที่ / เวลาและฟังก์ชัน

ตารางต่อไปนี้แสดงพฤติกรรมของตัวดำเนินการเลขคณิตพื้นฐาน -

ตัวดำเนินการ ตัวอย่าง ผลลัพธ์
+ วันที่ '2001-09-28' + จำนวนเต็ม '7' วันที่ '2001-10-05'
+ วันที่ '2001-09-28' + ช่วงเวลา '1 ชั่วโมง' ประทับเวลา '2001-09-28 01:00:00'
+ วันที่ '2001-09-28' + เวลา '03: 00 ' ประทับเวลา '2001-09-28 03:00:00'
+ ช่วงเวลา '1 วัน' + ช่วงเวลา '1 ชั่วโมง' ช่วง '1 วัน 01:00:00'
+ timestamp '2001-09-28 01:00' + ช่วง '23 ชั่วโมง ' ประทับเวลา '2001-09-29 00:00:00'
+ เวลา '01: 00 '+ ช่วงเวลา' 3 ชั่วโมง ' เวลา '04: 00: 00 น.
- - ช่วงเวลา '23 ชั่วโมง ' ช่วง '-23: 00: 00 น.
- วันที่ '2001-10-01' - วันที่ '2001-09-28' จำนวนเต็ม '3' (วัน)
- วันที่ '2001-10-01' - จำนวนเต็ม '7' วันที่ '2001-09-24'
- วันที่ '2001-09-28' - ช่วงเวลา '1 ชั่วโมง' เวลา '2001-09-27 23:00:00'
- เวลา '05: 00 '- เวลา '03: 00' ช่วงเวลา '02: 00: 00 น.
- เวลา '05: 00 '- ช่วงเวลา' 2 ชั่วโมง ' เวลา '03: 00: 00 น.
- เวลาประทับ '2001-09-28 23:00' - ช่วงเวลา '23 ชั่วโมง ' ประทับเวลา '2001-09-28 00:00:00'
- ช่วงเวลา '1 วัน' - ช่วงเวลา '1 ชั่วโมง' ช่วง '1 วัน -01: 00: 00 น.
- เวลาประทับ '2001-09-29 03:00' - ประทับเวลา '2001-09-27 12:00' ช่วง '1 วัน 15:00:00'
* 900 * ช่วงเวลา '1 วินาที' ช่วงเวลา '00: 15: 00 น.
* 21 * ช่วง '1 วัน' ช่วง '21 วัน '
* ความแม่นยำสองเท่า '3.5' * ช่วงเวลา '1 ชั่วโมง' ช่วงเวลา '03: 30: 00 น.
/ ช่วงเวลา '1 ชั่วโมง' / ความแม่นยำสองเท่า '1.5' ช่วงเวลา '00: 40: 00 '

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

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

ลบอาร์กิวเมนต์

2 วันที่ / เวลาปัจจุบัน ()

วันที่และเวลาปัจจุบัน

3 DATE_PART ()

รับฟิลด์ย่อย (เทียบเท่ากับการแยก)

4 สารสกัด ()

รับฟิลด์ย่อย

5 ISFINITE ()

ทดสอบวันที่เวลาและช่วงเวลาที่ จำกัด (ไม่ใช่ +/- อินฟินิตี้)

6 ยุติธรรม

ปรับช่วงเวลา

อายุ (ประทับเวลาประทับเวลา) อายุ (ประทับเวลา)

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

AGE(timestamp, timestamp)

เมื่อเรียกใช้ด้วยรูปแบบ TIMESTAMP ของอาร์กิวเมนต์ที่สอง AGE () จะลบอาร์กิวเมนต์ทำให้ได้ผลลัพธ์ "สัญลักษณ์" ที่ใช้ปีและเดือนและเป็นประเภท INTERVAL

2

AGE(timestamp)

เมื่อเรียกใช้โดยมีเพียง TIMESTAMP เป็นอาร์กิวเมนต์ AGE () จะลบออกจาก current_date (ตอนเที่ยงคืน)

ตัวอย่างของฟังก์ชัน AGE (timestamp, timestamp) คือ -

testdb=# SELECT AGE(timestamp '2001-04-10', timestamp '1957-06-13');

คำสั่ง PostgreSQL ข้างต้นจะให้ผลลัพธ์ดังต่อไปนี้ -

age
-------------------------
 43 years 9 mons 27 days

ตัวอย่างของฟังก์ชัน AGE (การประทับเวลา) คือ -

testdb=# select age(timestamp '1957-06-13');

คำสั่ง PostgreSQL ข้างต้นจะให้ผลลัพธ์ดังต่อไปนี้ -

age
--------------------------
 55 years 10 mons 22 days

วันที่ / เวลาปัจจุบัน ()

PostgreSQL มีฟังก์ชันจำนวนมากที่ส่งคืนค่าที่เกี่ยวข้องกับวันที่และเวลาปัจจุบัน ต่อไปนี้เป็นฟังก์ชั่นบางอย่าง -

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

CURRENT_DATE

ส่งวันที่ปัจจุบัน

2

CURRENT_TIME

แสดงค่าด้วยเขตเวลา

3

CURRENT_TIMESTAMP

แสดงค่าด้วยเขตเวลา

4

CURRENT_TIME(precision)

เลือกใช้พารามิเตอร์ที่มีความแม่นยำซึ่งทำให้ผลลัพธ์ถูกปัดเศษเป็นตัวเลขเศษส่วนจำนวนมากในฟิลด์วินาที

5

CURRENT_TIMESTAMP(precision)

เลือกใช้พารามิเตอร์ที่มีความแม่นยำซึ่งทำให้ผลลัพธ์ถูกปัดเศษเป็นตัวเลขเศษส่วนจำนวนมากในฟิลด์วินาที

6

LOCALTIME

แสดงค่าโดยไม่มีเขตเวลา

7

LOCALTIMESTAMP

แสดงค่าโดยไม่มีเขตเวลา

8

LOCALTIME(precision)

เลือกใช้พารามิเตอร์ที่มีความแม่นยำซึ่งทำให้ผลลัพธ์ถูกปัดเศษเป็นตัวเลขเศษส่วนจำนวนมากในฟิลด์วินาที

9

LOCALTIMESTAMP(precision)

เลือกใช้พารามิเตอร์ที่มีความแม่นยำซึ่งทำให้ผลลัพธ์ถูกปัดเศษเป็นตัวเลขเศษส่วนจำนวนมากในฟิลด์วินาที

ตัวอย่างการใช้ฟังก์ชันจากตารางด้านบน -

testdb=# SELECT CURRENT_TIME;
       timetz
--------------------
 08:01:34.656+05:30
(1 row)


testdb=# SELECT CURRENT_DATE;
    date
------------
 2013-05-05
(1 row)


testdb=# SELECT CURRENT_TIMESTAMP;
              now
-------------------------------
 2013-05-05 08:01:45.375+05:30
(1 row)


testdb=# SELECT CURRENT_TIMESTAMP(2);
         timestamptz
------------------------------
 2013-05-05 08:01:50.89+05:30
(1 row)


testdb=# SELECT LOCALTIMESTAMP;
       timestamp
------------------------
 2013-05-05 08:01:55.75
(1 row)

PostgreSQL ยังมีฟังก์ชันที่ส่งคืนเวลาเริ่มต้นของคำสั่งปัจจุบันเช่นเดียวกับเวลาปัจจุบันที่แท้จริงในทันทีที่เรียกใช้ฟังก์ชัน ฟังก์ชันเหล่านี้คือ -

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

transaction_timestamp()

เทียบเท่ากับ CURRENT_TIMESTAMP แต่ตั้งชื่อเพื่อให้สะท้อนถึงสิ่งที่ส่งคืน

2

statement_timestamp()

ส่งคืนเวลาเริ่มต้นของคำสั่งปัจจุบัน

3

clock_timestamp()

ส่งคืนเวลาปัจจุบันที่แท้จริงดังนั้นค่าของมันจึงเปลี่ยนไปแม้ในคำสั่ง SQL คำสั่งเดียว

4

timeofday()

ส่งคืนเวลาปัจจุบันจริง แต่เป็นสตริงข้อความที่จัดรูปแบบแล้วแทนที่จะเป็นการประทับเวลาที่มีค่าโซนเวลา

5

now()

เป็น PostgreSQL แบบดั้งเดิมที่เทียบเท่ากับ transaction_timestamp ()

DATE_PART (ข้อความการประทับเวลา) DATE_PART (ข้อความช่วงเวลา) DATE_TRUNC (ข้อความการประทับเวลา)

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

DATE_PART('field', source)

ฟังก์ชันเหล่านี้ได้รับฟิลด์ย่อย ฟิลด์พารามิเตอร์จะต้องมีค่าสตริงไม่ชื่อ

ชื่อเขตข้อมูลที่ถูกต้อง ได้แก่ศตวรรษวันทศวรรษดาวโดยุคสมัยชั่วโมงไอโซโดวไอโซเอียร์ไมโครวินาทีสหัสวรรษมิลลิวินาทีนาทีเดือนไตรมาสที่สองเขตเวลาเขตเวลา _ ชั่วโมงเขตเวลา _ นาทีสัปดาห์ปี

2

DATE_TRUNC('field', source)

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

ค่าที่ถูกต้องสำหรับฟิลด์คือไมโครวินาทีมิลลิวินาทีวินาทีนาทีชั่วโมงวันสัปดาห์เดือนไตรมาสปีทศวรรษศตวรรษสหัสวรรษ

ต่อไปนี้เป็นตัวอย่างสำหรับฟังก์ชัน DATE_PART ( 'field' , source) -

testdb=# SELECT date_part('day', TIMESTAMP '2001-02-16 20:38:40');
 date_part
-----------
        16
(1 row)


testdb=# SELECT date_part('hour', INTERVAL '4 hours 3 minutes');
 date_part
-----------
         4
(1 row)

ต่อไปนี้เป็นตัวอย่างสำหรับฟังก์ชัน DATE_TRUNC ( 'field' , source) -

testdb=# SELECT date_trunc('hour', TIMESTAMP '2001-02-16 20:38:40');
     date_trunc
---------------------
 2001-02-16 20:00:00
(1 row)


testdb=# SELECT date_trunc('year', TIMESTAMP '2001-02-16 20:38:40');
     date_trunc
---------------------
 2001-01-01 00:00:00
(1 row)

EXTRACT (ฟิลด์จากการประทับเวลา), EXTRACT (ฟิลด์จากช่วงเวลา)

EXTRACT(field FROM source)ฟังก์ชันดึงฟิลด์ย่อยเช่นปีหรือชั่วโมงจากค่าวันที่ / เวลา แหล่งที่มาจะต้องมีการแสดงออกค่าของชนิดประทับเวลาเวลาหรือช่วงเวลา สนามเป็นตัวระบุหรือสตริงที่เลือกสิ่งที่จะดึงข้อมูลจากมูลค่าของแหล่งที่มา ฟังก์ชั่นสารสกัดจากผลตอบแทนค่าประเภทความแม่นยำสอง

ต่อไปนี้เป็นชื่อฟิลด์ที่ถูกต้อง (คล้ายกับชื่อฟิลด์ฟังก์ชัน DATE_PART): ศตวรรษวันทศวรรษดาวโจนส์ยุคสมัยชั่วโมงไอโซโดว isoyear ไมโครวินาทีสหัสวรรษมิลลิวินาทีนาทีเดือนไตรมาสที่สองเขตเวลาเขตเวลาและชั่วโมง , timezone_minute, สัปดาห์, ปี

ต่อไปนี้เป็นตัวอย่างของฟังก์ชันEXTRACT ( 'field' , source) -

testdb=# SELECT EXTRACT(CENTURY FROM TIMESTAMP '2000-12-16 12:21:13');
 date_part
-----------
        20
(1 row)


testdb=# SELECT EXTRACT(DAY FROM TIMESTAMP '2001-02-16 20:38:40');
 date_part
-----------
        16
(1 row)

ISFINITE (วันที่), ISFINITE (ประทับเวลา), ISFINITE (ช่วงเวลา)

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

ISFINITE(date)

ทดสอบวันที่แน่นอน

2

ISFINITE(timestamp)

ทดสอบการประทับเวลา จำกัด

3

ISFINITE(interval)

ทดสอบช่วงเวลา จำกัด

ต่อไปนี้เป็นตัวอย่างของฟังก์ชัน ISFINITE () -

testdb=# SELECT isfinite(date '2001-02-16');
 isfinite
----------
 t
(1 row)


testdb=# SELECT isfinite(timestamp '2001-02-16 21:28:30');
 isfinite
----------
 t
(1 row)


testdb=# SELECT isfinite(interval '4 hours');
 isfinite
----------
 t
(1 row)

JUSTIFY_DAYS (ช่วงเวลา), JUSTIFY_HOURS (ช่วงเวลา), JUSTIFY_INTERVAL (ช่วงเวลา)

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

JUSTIFY_DAYS(interval)

ปรับช่วงเวลาเพื่อให้ช่วงเวลา 30 วันแสดงเป็นเดือน ส่งคืนไฟล์interval ชนิด

2

JUSTIFY_HOURS(interval)

ปรับช่วงเวลาเพื่อให้ช่วงเวลา 24 ชั่วโมงแสดงเป็นวัน ส่งคืนไฟล์interval ชนิด

3

JUSTIFY_INTERVAL(interval)

ปรับช่วงเวลาโดยใช้ JUSTIFY_DAYS และ JUSTIFY_HOURS พร้อมการปรับป้ายเพิ่มเติม ส่งคืนไฟล์interval ชนิด

ต่อไปนี้เป็นตัวอย่างสำหรับฟังก์ชัน ISFINITE () -

testdb=# SELECT justify_days(interval '35 days');
 justify_days
--------------
 1 mon 5 days
(1 row)


testdb=# SELECT justify_hours(interval '27 hours');
 justify_hours
----------------
 1 day 03:00:00
(1 row)


testdb=# SELECT justify_interval(interval '1 mon -1 hour');
 justify_interval
------------------
 29 days 23:00:00
(1 row)