濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 在PostgreSQL中使用日期類型時(shí)一些需要注意的地方

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

熱門標(biāo)簽:湖南保險(xiǎn)智能外呼系統(tǒng)產(chǎn)品介紹 河北便宜電銷機(jī)器人軟件 怎么申請(qǐng)400熱線電話 怎么去開發(fā)一個(gè)電銷機(jī)器人 泗洪正規(guī)電話機(jī)器人找哪家 南昌呼叫中心外呼系統(tǒng)哪家好 ai電話電話機(jī)器人 小程序智能電話機(jī)器人 簡(jiǎn)單的智能語(yǔ)音電銷機(jī)器人

 當(dāng)我們這些使用Rails的人看到例如5.weeks.from_nowor3.days.ago + 2.hours時(shí)并不會(huì)感到驚訝。同樣,PostgreSQL也可以做到,你可以通過(guò)簡(jiǎn)單調(diào)用PostgreSQL內(nèi)置函數(shù)來(lái)實(shí)現(xiàn)相同的功能。
當(dāng)前時(shí)間/日期/時(shí)間戳

獲取當(dāng)前時(shí)間的方式有很多種,在這之前我們需要知道以下兩種類型的區(qū)別:

  •     總是返回當(dāng)前的值 (clock_timestamp())
  •     總是返回當(dāng)前值,但在事務(wù)中它返回的是事務(wù)開始的時(shí)間(now())

讓我們看下面這個(gè)例子
 

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

你會(huì)發(fā)現(xiàn),語(yǔ)句執(zhí)行時(shí)候clock_timestamp()的返回值每次都發(fā)生了改變,但是now()總是返回相同的值。當(dāng)你需要考慮時(shí)區(qū)時(shí),你應(yīng)該特別注意這兩個(gè)函數(shù)差異。

時(shí)間區(qū)間:比如3天前

使用interval操作符你可以輕松的構(gòu)建一個(gè)時(shí)間區(qū)間,例如

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

你可以看到,我們可以用interval操作符來(lái)簡(jiǎn)單的進(jìn)行數(shù)學(xué)運(yùn)算,這特別適合于構(gòu)建例如3天前這樣的時(shí)間區(qū)間,比如:
 

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

獲取星期幾

有些時(shí)候?qū)τ谝粋€(gè)給定的時(shí)間,你僅僅只想知道的是這天是星期幾或者是它屬于那個(gè)世紀(jì)的更或者你只想知道它是一年中的第幾天。PostgreSQL中的extract()函數(shù)提供了這種功能。

如下例子是在8月26日 星期一進(jìn)行測(cè)試的。
 

postgres=# SELECT extract(DAY FROM now());
 date_part
-----------
    26
 
postgres=# SELECT extract(DOW FROM now());
 date_part
-----------
     1

extract()還有其他更強(qiáng)大的功能,詳情請(qǐng)參閱官方文檔,在這里只列舉了一小部分:

  •     day
  •     century
  •     dow(day of week)
  •     doy(day of year)
  •     minute
  •     month
  •     year


時(shí)區(qū)轉(zhuǎn)換

有些時(shí)候,時(shí)區(qū)轉(zhuǎn)換對(duì)于特定時(shí)間在不同時(shí)區(qū)顯示特別有用。AT TIME ZONE提供了這種功能,它是如何做到的?我們將在一個(gè)事務(wù)中進(jìn)行演示,因?yàn)橥皇聞?wù)中now()函數(shù)總是返回相同的值,從而我們可以很容易看到同一時(shí)間在不同時(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

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

標(biāo)簽:景德鎮(zhèn) 荊門 那曲 江蘇 淮安 威海 瀘州 柳州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在PostgreSQL中使用日期類型時(shí)一些需要注意的地方》,本文關(guān)鍵詞  在,PostgreSQL,中,使用,日期,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《在PostgreSQL中使用日期類型時(shí)一些需要注意的地方》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于在PostgreSQL中使用日期類型時(shí)一些需要注意的地方的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    建湖县| 灵石县| 安龙县| 东乌珠穆沁旗| 慈溪市| 东港市| 西青区| 巫山县| 墨江| 贵州省| 泸溪县| 唐山市| 苗栗市| 十堰市| 乌什县| 台东县| 玉门市| 赣州市| 于田县| 南靖县| 尉犁县| 罗源县| 玉门市| 霍山县| 巫山县| 基隆市| 尉犁县| 东乌| 绥江县| 房山区| 延津县| 宁德市| 舞阳县| 平武县| 兴义市| 平远县| 阜新市| 泾阳县| 浙江省| 兴安县| 东港市|