PostgreSQL中如何使用日期類型,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供甘德網(wǎng)站建設、甘德做網(wǎng)站、甘德網(wǎng)站設計、甘德網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、甘德企業(yè)網(wǎng)站模板建站服務,十多年甘德做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。
當前時間/日期/時間戳
獲取當前時間的方式有很多種,在這之前我們需要知道以下兩種類型的區(qū)別:
總是返回當前的值 (clock_timestamp())
總是返回當前值,但在事務中它返回的是事務開始的時間(now())
讓我們看下面這個例子
postgres=# BEGIN; postgres=# SELECT now(); now ------------------------------- 2013-08-26 12:17:43.182331+02 postgres=# SELECT now(); now ------------------------------- 2013-08-26 12:17:43.182331+02 postgres=# SELECT clock_timestamp(); clock_timestamp ------------------------------- 2013-08-26 12:17:50.698413+02 postgres=# SELECT clock_timestamp(); clock_timestamp ------------------------------- 2013-08-26 12:17:51.123905+02
你會發(fā)現(xiàn),語句執(zhí)行時候clock_timestamp()的返回值每次都發(fā)生了改變,但是now()總是返回相同的值。當你需要考慮時區(qū)時,你應該特別注意這兩個函數(shù)差異。
時間區(qū)間:比如3天前
使用interval操作符你可以輕松的構建一個時間區(qū)間,例如
interval '1 day'
interval '5 days'
interval '5 days' + interval '3 hours'
interval '5 days 3 hours'
你可以看到,我們可以用interval操作符來簡單的進行數(shù)學運算,這特別適合于構建例如3天前這樣的時間區(qū)間,比如:
postgres=# SELECT now() - interval '3 days'; ?column? ------------------------------- 2013-08-23 12:23:40.069717+02
獲取星期幾
有些時候?qū)τ谝粋€給定的時間,你僅僅只想知道的是這天是星期幾或者是它屬于那個世紀的更或者你只想知道它是一年中的第幾天。PostgreSQL中的extract()函數(shù)提供了這種功能。
如下例子是在8月26日 星期一進行測試的。
postgres=# SELECT extract(DAY FROM now()); date_part ----------- 26 postgres=# SELECT extract(DOW FROM now()); date_part ----------- 1
extract()還有其他更強大的功能,詳情請參閱官方文檔,在這里只列舉了一小部分:
day
century
dow(day of week)
doy(day of year)
minute
month
year
時區(qū)轉換
有些時候,時區(qū)轉換對于特定時間在不同時區(qū)顯示特別有用。AT TIME ZONE提供了這種功能,它是如何做到的?我們將在一個事務中進行演示,因為同一事務中now()函數(shù)總是返回相同的值,從而我們可以很容易看到同一時間在不同時區(qū)顯示的差別。
postgres=# BEGIN; BEGIN postgres=# SELECT now(); now ------------------------------- 2013-08-26 12:39:39.122218+02 postgres=# SELECT now() AT TIME ZONE 'GMT'; timezone ---------------------------- 2013-08-26 10:39:39.122218 postgres=# SELECT now() AT TIME ZONE 'GMT+1'; timezone ---------------------------- 2013-08-26 09:39:39.122218 postgres=# SELECT now() AT TIME ZONE 'PST'; timezone ---------------------------- 2013-08-26 02:39:39.122218
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)網(wǎng)站建設公司,的支持。