婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 在PostgreSQL中使用日期類型時一些需要注意的地方

在PostgreSQL中使用日期類型時一些需要注意的地方

熱門標簽:湖南保險智能外呼系統產品介紹 河北便宜電銷機器人軟件 怎么申請400熱線電話 怎么去開發一個電銷機器人 泗洪正規電話機器人找哪家 南昌呼叫中心外呼系統哪家好 ai電話電話機器人 小程序智能電話機器人 簡單的智能語音電銷機器人

 當我們這些使用Rails的人看到例如5.weeks.from_nowor3.days.ago + 2.hours時并不會感到驚訝。同樣,PostgreSQL也可以做到,你可以通過簡單調用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

您可能感興趣的文章:
  • PostgreSQL 如何獲取當前日期時間及注意事項
  • JDBC中使用Java8的日期LocalDate和LocalDateTime操作mysql、postgresql
  • PostgreSQL中常用的時間日期腳本使用教程
  • Postgresql 通過出生日期獲取年齡的操作

標簽:景德鎮 荊門 那曲 江蘇 淮安 威海 瀘州 柳州

巨人網絡通訊聲明:本文標題《在PostgreSQL中使用日期類型時一些需要注意的地方》,本文關鍵詞  在,PostgreSQL,中,使用,日期,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《在PostgreSQL中使用日期類型時一些需要注意的地方》相關的同類信息!
  • 本頁收集關于在PostgreSQL中使用日期類型時一些需要注意的地方的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 河源市| 临海市| 利辛县| 潮安县| 淮北市| 娄烦县| 深水埗区| 泾川县| 香格里拉县| 镇巴县| 鹿泉市| 深泽县| 鄯善县| 巨鹿县| 利辛县| 饶平县| 略阳县| 象山县| 内江市| 新巴尔虎左旗| 萍乡市| 武强县| 贡山| 兴化市| 瑞金市| 涿鹿县| 许昌县| 雅江县| 邯郸市| 巫溪县| 龙海市| 安化县| 嘉兴市| 宕昌县| 渝北区| 阳西县| 会昌县| 含山县| 和田县| 遂川县| 罗源县|