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)