在PostgreSQL中使用日期類型時(shí)一些需要注意的地方
當(dāng)我們這些使用Rails的人看到例如5.weeks.from_nowor3.days.ago + 2.hours時(shí)并不會(huì)感到驚訝。同樣,PostgreSQL也可以做到,你可以通過簡(jiǎn)單調(diào)用PostgreSQL內(nèi)置函數(shù)來實(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),語句執(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操作符來簡(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
相關(guān)文章
Clickhouse系列之整合Hive數(shù)據(jù)倉(cāng)庫(kù)示例詳解
這篇文章主要為大家介紹了Clickhouse系列之整合Hive數(shù)據(jù)倉(cāng)庫(kù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
關(guān)于數(shù)據(jù)庫(kù)設(shè)計(jì)中主鍵問題的思考
數(shù)據(jù)庫(kù)主鍵在數(shù)據(jù)庫(kù)中占有重要地位。主鍵的選取策略決定了系統(tǒng)是否可靠、易用、高效。本文探討了數(shù)據(jù)庫(kù)設(shè)計(jì)過程當(dāng)中常見的主鍵選取策略,并剖析了其做主鍵的優(yōu)缺點(diǎn),提出了相應(yīng)的解決問題的方法2013-08-08
SQL SERVER 里的錯(cuò)誤處理(try catch)
SQL SERVER里,也有TRY CATCH。格式如下2009-02-02
關(guān)于SQL注入繞過的一些知識(shí)點(diǎn)
網(wǎng)上關(guān)于SQL注入的繞過技巧有很多,最近正好空下來,想著整理下關(guān)于SQL注入繞過的一些姿勢(shì)。歡迎大牛補(bǔ)充,下面這篇文章主要介紹了關(guān)于SQL注入繞過的一些知識(shí)點(diǎn),總結(jié)的還是相對(duì)比較全面的,需要的朋友可以參考下。2017-03-03
如何查看Navicat加密的數(shù)據(jù)庫(kù)密碼
本機(jī)裝的MySQL數(shù)據(jù)庫(kù)密碼忘記了,打開了Navicat連接過數(shù)據(jù)庫(kù),不過密碼是加密的,怎么辦呢?今天小編給大家分享如何查看Navicat加密的數(shù)據(jù)庫(kù)密碼,感興趣的朋友一起看看吧2023-04-04
一些關(guān)于數(shù)據(jù)存儲(chǔ)和查詢優(yōu)化的想法
今天咨詢了一下高手,關(guān)于數(shù)據(jù)存儲(chǔ)和查詢的問題,最終目的就是快,大家可以適當(dāng)?shù)氖褂?/div> 2012-05-05最新評(píng)論

