共計 2458 個字符,預計需要花費 7 分鐘才能閱讀完成。
這篇文章將為大家詳細講解有關 SQL 中 datetime 和 interval 數據類型的作用是什么,文章內容質量較高,因此丸趣 TV 小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
SQL 數據類型
如果你想進一步了解 SQL 數據類型,請閱讀 SQL 基礎:字符串型數據類型,這篇文章的范圍覆蓋了 SQL 中的通用數據類型并說明了各種字符串數據類型的用法,SQL 基礎:數字數據類型詳細介紹了數字數據類型。
Datetime
用于表示時間或者日期的數據類型都屬于 datetime 類型。每一種 datetime 數據類型都有他自己的用于獲取值的長度和它所保存信息的手段,如天、月、分鐘、秒、秒的小數等等。
實際上,datetime 的實現形式隨著定義它的標準不同而擁有不同的長度和格式;然而,各個公司定義的類型都內在地符合下述規則。舉例來說,時標(timestamp)的某個實現可能沒有分隔符,隨著細節的規范不同,長度和格式也發生變化,在某些場合以空格做為間隔符。Datetime 數據類型包括:DATA、TIME 和 TIMESTAMP。讓我們仔細研究這些分類,首先我們看看 DATA。
DATA
用法:DATA
DATA 類型允許沒有參數,如精度。
DATA 的字段包括年、月和日。
DATA 的長度為十個字符: YYYY-MM-DD。(Y 表示年、M 表示月、D 表示日。)
它只允許與其它 DATA 類型字段相比較。
允許的數字必須符合公歷的規范。
TIME
用法:TIME(精度)
該類型包含了小時、分和秒,格式為 hh:mm:ss(h 表示小時、m 表示分、s 表示秒)
精度可選擇,(……)
時間以世界標準時間(Universal Coordinated Time,UTC)為準,即 00:00:00 表示. 格林威治的午夜,服務器的時區隱含的。
如果不需要秒的小數部分,那么 TIME 的長度為八個字符。否則就是八位長度在加上精度:hh:mm:ss.p。
它只能與其它 TIME 類型數據進行比較。
如果沒有指定精度,精度默認為 0。
TIME WITH TIME ZONE
用法:TIME (精度) WITH TIME ZONE
這個值要符合 TIME 數據類型
TIMEZONE 部分表示相對 UTC 的時差:00:00:00+hh:mm。它的范圍為 -12:59 到 13:00。
精度表示秒的小數部分。
帶有 TIMEZONE 的 TIME 長度為 14 個字符加上精度,在加上一個分隔符。
只可以與帶有 TIMEZONE 的 TIME 類型數據進行比較
TIMESTAMP
用法:TIMESTAMP(精度)
該類型包含有年、月、日、時、分、秒,格式為:YYYY-MM-DD hh:mm:ss.。
可以包括秒的小數部分,這由定義的精度決定。
它的日期部分符合公歷標準,時間部分為 UTC 格式。默認為當地時區。
時標的長度為 19 個字符,加上精度,在加上精度分隔符。
許多系統偏離上述定義的長度,如 UNIX 風格時標格式為:,YYYY-MM-DD hh:mm:ss.p。
如果沒有定義精度,默認值為 6,但是許多公司默認為 0,所以請參考你的開發文檔。
時標只可以與其它 TIMESTAMP 類型的值相比較。
TIMESTAMP WITH TIME ZONE
用法:TIMESTAMP(精度)WITH TIME ZONE
時標部分符合上述 TIMESTAWP 的規則。
精度代表秒的小數部分。
時區部分的要求和 TIME WITH TIME ZONE 一樣,即時區符合 UTC 規范,范圍在 -12:59 到 +13:00 之間。
總長度為 25 個字符,加上精度,加上一個精度分隔符:YYYY-MM-DD hh:mm:ss.p。
它只能與其它 TIMESTAMP WITH TIME ZONE 類型的數據進行比較。
Interval
Interval 用于表示時間尺度。例如,你可以用操作符(將在下面進行解釋)去計算兩個日期間天數并加以保存。
各個公司在處理 interval 上有很大的不同——有些公司提供不同的度量單位,如年或者分鐘,而有些公司在根本就不支持 interval。SQL92 標準的 interval 類型只提供一種子類型:INTERVAL。
INTERVAL
用法: INTERVAL (限定語)
有兩種類型的 interval:一種為“年份-月份”,即保存年份和月份(YYYY-MM);一種為“天-時間”(DD HH:MM:SS),用來保存天數、小時、分鐘和秒。
限定語——在某些數據庫中 interval 前導精度(lead precision)——根據其值來指示 interval 采用“年份-月份”還是“天-時間”方式。
interval 可正可負。
當與其它 interval 類型變量相比較時,結果保持最大精度,如有必要則補零。
INTERVAL 全部由整數組成,除了含有小數的秒之外。
“年份-月份”類型的 interval 變量只能與其它的“年份-月份”的 interval 變量進行比較。“天-時間”類型也與此類似。
操作符
操作結果類型
當處理日期時間時,時區保持不變——盡管有些數據庫為了比較而將其中的一個時區轉換為另一個。存在一些操作關鍵字,如 OVERLAPS 和 EXTRACT,它們用于操作和比較 datetime 類型數據。然而,不同的數據庫在這些操作關鍵字用法和支持方式上有著很大的不同。
OVERLAPS 用于計算時間交疊的跨度,其操作對象可以是兩個 datetime 也可以是一個 datetime 和一個 interval。EXTRACT 用于提取 datetime 或者 interval 類型數據的某個部分,如在 DATA 類型數據中提取月份。
數據類型
由于已建立的標準是為了各公司在現有基礎上實現實際上的數據類型的,因此在具體限制、參數和數據類型等方面,你還是需要經常參考你的數據庫文檔。
關于 SQL 中 datetime 和 interval 數據類型的作用是什么就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。