91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PostgreSQL中如何使用日期類型

發布時間:2021-07-26 16:14:00 來源:億速云 閱讀:109 作者:Leah 欄目:數據庫

PostgreSQL中如何使用日期類型,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。


當前時間/日期/時間戳

獲取當前時間的方式有很多種,在這之前我們需要知道以下兩種類型的區別:

  •     總是返回當前的值 (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

你會發現,語句執行時候clock_timestamp()的返回值每次都發生了改變,但是now()總是返回相同的值。當你需要考慮時區時,你應該特別注意這兩個函數差異。

時間區間:比如3天前

使用interval操作符你可以輕松的構建一個時間區間,例如

  •     interval '1 day'

  •     interval '5 days'

  •     interval '5 days' + interval '3 hours'

  •     interval '5 days 3 hours'

你可以看到,我們可以用interval操作符來簡單的進行數學運算,這特別適合于構建例如3天前這樣的時間區間,比如:
 

postgres=# SELECT now() - interval '3 days';
      ?column?
-------------------------------
 2013-08-23 12:23:40.069717+02

獲取星期幾

有些時候對于一個給定的時間,你僅僅只想知道的是這天是星期幾或者是它屬于那個世紀的更或者你只想知道它是一年中的第幾天。PostgreSQL中的extract()函數提供了這種功能。

如下例子是在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


時區轉換

有些時候,時區轉換對于特定時間在不同時區顯示特別有用。AT TIME ZONE提供了這種功能,它是如何做到的?我們將在一個事務中進行演示,因為同一事務中now()函數總是返回相同的值,從而我們可以很容易看到同一時間在不同時區顯示的差別。
 

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

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

右玉县| 乌兰察布市| 佛教| 布拖县| 玉林市| 高清| 铜川市| 兴国县| 贡嘎县| 平和县| 壤塘县| 琼海市| 拉孜县| 遂溪县| 砀山县| 株洲市| 琼中| 荣成市| 沙田区| 都匀市| 望江县| 乐山市| 九台市| 信阳市| 苍溪县| 贡觉县| 乡城县| 会东县| 丹凤县| 玉溪市| 祁东县| 老河口市| 旺苍县| 泰安市| 岳西县| 临安市| 安庆市| 平定县| 峨眉山市| 广丰县| 涞源县|