datetime和interval是兩種與時間有關(guān)的數(shù)據(jù)類型。它們的作用體現(xiàn)在以下幾個方面:創(chuàng)建或者更改記錄庫中的某條記錄、當某個時間發(fā)生時運行記錄、或者計算某個datetime變量建立后所經(jīng)歷過的時間。本文將介紹SQL92標準對上述兩種數(shù)據(jù)類型的描述。
SQL數(shù)據(jù)類型
如果你想進一步了解SQL數(shù)據(jù)類型,請閱讀SQL基礎(chǔ):字符串型數(shù)據(jù)類型,這篇文章的范圍覆蓋了SQL中的通用數(shù)據(jù)類型并說明了各種字符串數(shù)據(jù)類型的用法,SQL基礎(chǔ):數(shù)字數(shù)據(jù)類型詳細介紹了數(shù)字數(shù)據(jù)類型。
Datetime
用于表示時間或者日期的數(shù)據(jù)類型都屬于datetime類型。每一種datetime數(shù)據(jù)類型都有他自己的用于獲取值的長度和它所保存信息的手段,如天、月、分鐘、秒、秒的小數(shù)等等。
實際上,datetime的實現(xiàn)形式隨著定義它的標準不同而擁有不同的長度和格式;然而,各個公司定義的類型都內(nèi)在地符合下述規(guī)則。舉例來說,時標(timestamp)的某個實現(xiàn)可能沒有分隔符,隨著細節(jié)的規(guī)范不同,長度和格式也發(fā)生變化,在某些場合以空格做為間隔符。Datetime數(shù)據(jù)類型包括:DATA、TIME和TIMESTAMP。讓我們仔細研究這些分類,首先我們看看DATA。
DATA
用法:DATA
DATA類型允許沒有參數(shù),如精度。
DATA的字段包括年、月和日。
DATA的長度為十個字符: YYYY-MM-DD。(Y表示年、M表示月、D表示日。)
它只允許與其它DATA類型字段相比較。
允許的數(shù)字必須符合公歷的規(guī)范。
TIME
用法:TIME(精度)
該類型包含了小時、分和秒,格式為hh:mm:ss(h表示小時、m表示分、s表示秒)
精度可選擇,(……)
時間以世界標準時間(Universal Coordinated Time,UTC)為準,即00:00:00表示.格林威治的午夜,服務器的時區(qū)隱含的。
如果不需要秒的小數(shù)部分,那么TIME的長度為八個字符。否則就是八位長度在加上精度:hh:mm:ss.p。
它只能與其它TIME類型數(shù)據(jù)進行比較。
如果沒有指定精度,精度默認為0。
TIME WITH TIME ZONE
用法:TIME (精度) WITH TIME ZONE
這個值要符合TIME數(shù)據(jù)類型
TIMEZONE部分表示相對UTC的時差:00:00:00+hh:mm。它的范圍為-12:59到13:00。
精度表示秒的小數(shù)部分。
帶有TIMEZONE的TIME長度為14個字符加上精度,在加上一個分隔符。
只可以與帶有TIMEZONE的TIME類型數(shù)據(jù)進行比較
TIMESTAMP
用法:TIMESTAMP(精度)
該類型包含有年、月、日、時、分、秒,格式為:YYYY-MM-DD hh:mm:ss.。
可以包括秒的小數(shù)部分,這由定義的精度決定。
它的日期部分符合公歷標準,時間部分為UTC格式。默認為當?shù)貢r區(qū)。
時標的長度為19個字符,加上精度,在加上精度分隔符。
許多系統(tǒng)偏離上述定義的長度,如UNIX風格時標格式為:,YYYY-MM-DD hh:mm:ss.p。
如果沒有定義精度,默認值為6,但是許多數(shù)據(jù)庫公司默認為0,所以請參考你的開發(fā)文檔。
時標只可以與其它TIMESTAMP類型的值相比較。
TIMESTAMP WITH TIME ZONE
SQL數(shù)據(jù)類型
如果你想進一步了解SQL數(shù)據(jù)類型,請閱讀SQL基礎(chǔ):字符串型數(shù)據(jù)類型,這篇文章的范圍覆蓋了SQL中的通用數(shù)據(jù)類型并說明了各種字符串數(shù)據(jù)類型的用法,SQL基礎(chǔ):數(shù)字數(shù)據(jù)類型詳細介紹了數(shù)字數(shù)據(jù)類型。
Datetime
用于表示時間或者日期的數(shù)據(jù)類型都屬于datetime類型。每一種datetime數(shù)據(jù)類型都有他自己的用于獲取值的長度和它所保存信息的手段,如天、月、分鐘、秒、秒的小數(shù)等等。
實際上,datetime的實現(xiàn)形式隨著定義它的標準不同而擁有不同的長度和格式;然而,各個公司定義的類型都內(nèi)在地符合下述規(guī)則。舉例來說,時標(timestamp)的某個實現(xiàn)可能沒有分隔符,隨著細節(jié)的規(guī)范不同,長度和格式也發(fā)生變化,在某些場合以空格做為間隔符。Datetime數(shù)據(jù)類型包括:DATA、TIME和TIMESTAMP。讓我們仔細研究這些分類,首先我們看看DATA。
DATA
用法:DATA
DATA類型允許沒有參數(shù),如精度。
DATA的字段包括年、月和日。
DATA的長度為十個字符: YYYY-MM-DD。(Y表示年、M表示月、D表示日。)
它只允許與其它DATA類型字段相比較。
允許的數(shù)字必須符合公歷的規(guī)范。
TIME
用法:TIME(精度)
該類型包含了小時、分和秒,格式為hh:mm:ss(h表示小時、m表示分、s表示秒)
精度可選擇,(……)
時間以世界標準時間(Universal Coordinated Time,UTC)為準,即00:00:00表示.格林威治的午夜,服務器的時區(qū)隱含的。
如果不需要秒的小數(shù)部分,那么TIME的長度為八個字符。否則就是八位長度在加上精度:hh:mm:ss.p。
它只能與其它TIME類型數(shù)據(jù)進行比較。
如果沒有指定精度,精度默認為0。
TIME WITH TIME ZONE
用法:TIME (精度) WITH TIME ZONE
這個值要符合TIME數(shù)據(jù)類型
TIMEZONE部分表示相對UTC的時差:00:00:00+hh:mm。它的范圍為-12:59到13:00。
精度表示秒的小數(shù)部分。
帶有TIMEZONE的TIME長度為14個字符加上精度,在加上一個分隔符。
只可以與帶有TIMEZONE的TIME類型數(shù)據(jù)進行比較
TIMESTAMP
用法:TIMESTAMP(精度)
該類型包含有年、月、日、時、分、秒,格式為:YYYY-MM-DD hh:mm:ss.。
可以包括秒的小數(shù)部分,這由定義的精度決定。
它的日期部分符合公歷標準,時間部分為UTC格式。默認為當?shù)貢r區(qū)。
時標的長度為19個字符,加上精度,在加上精度分隔符。
許多系統(tǒng)偏離上述定義的長度,如UNIX風格時標格式為:,YYYY-MM-DD hh:mm:ss.p。
如果沒有定義精度,默認值為6,但是許多數(shù)據(jù)庫公司默認為0,所以請參考你的開發(fā)文檔。
時標只可以與其它TIMESTAMP類型的值相比較。
TIMESTAMP WITH TIME ZONE