熱點推薦:
您现在的位置: 電腦知識網 >> 編程 >> SQL Server >> 正文

跟我學SQL:datetime和interval數據類型

2013-11-15 14:40:45  來源: SQL Server 

  datetime和interval是兩種與時間有關的數據類型它們的作用體現在以下幾個方面創建或者更改記錄庫中的某條記錄當某個時間發生時運行記錄或者計算某個datetime變量建立後所經歷過的時間本文將介紹SQL標准對上述兩種數據類型的描述
  
  
  
  
  SQL數據類型
  
  如果你想進一步了解SQL數據類型請閱讀SQL基礎字符串型數據類型這篇文章的范圍覆蓋了SQL中的通用數據類型並說明了各種字符串數據類型的用法SQL基礎數字數據類型詳細介紹了數字數據類型
  
  
  
  Datetime
  用於表示時間或者日期的數據類型都屬於datetime類型每一種datetime數據類型都有他自己的用於獲取值的長度和它所保存信息的手段如天分鐘秒的小數等等
  
  實際上datetime的實現形式隨著定義它的標准不同而擁有不同的長度和格式然而各個公司定義的類型都內在地符合下述規則舉例來說時標(timestamp)的某個實現可能沒有分隔符隨著細節的規范不同長度和格式也發生變化在某些場合以空格做為間隔符Datetime數據類型包括DATATIME和TIMESTAMP讓我們仔細研究這些分類首先我們看看DATA
  
  DATA
  用法DATA
  
  DATA類型允許沒有參數如精度
  DATA的字段包括年月和日
  DATA的長度為十個字符 YYYYMMDD(Y表示年M表示月D表示日
  它只允許與其它DATA類型字段相比較
  允許的數字必須符合公歷的規范
  TIME
  用法TIME(精度)
  
  該類型包含了小時分和秒格式為hh:mm:ss(h表示小時m表示分s表示秒)
  精度可選擇(……)
  時間以世界標准時間(Universal Coordinated TimeUTC)為准::表示格林威治的午夜服務器的時區隱含的
  如果不需要秒的小數部分那麼TIME的長度為八個字符否則就是八位長度在加上精度hh:mm:ssp
  它只能與其它TIME類型數據進行比較
  如果沒有指定精度精度默認為
  
  TIME WITH TIME ZONE
  
  
  用法TIME (精度) WITH TIME ZONE
  
  這個值要符合TIME數據類型
  TIMEZONE部分表示相對UTC的時差::+hh:mm它的范圍為::
  精度表示秒的小數部分
  帶有TIMEZONE的TIME長度為個字符加上精度在加上一個分隔符
  只可以與帶有TIMEZONE的TIME類型數據進行比較
  TIMESTAMP
  
  用法TIMESTAMP(精度)
  
  該類型包含有年格式為YYYYMMDD hh:mm:ss
  可以包括秒的小數部分這由定義的精度決定
  它的日期部分符合公歷標准時間部分為UTC格式默認為當地時區
  時標的長度為個字符加上精度在加上精度分隔符
  許多系統偏離上述定義的長度如UNIX風格時標格式為YYYYMMDD hh:mm:ssp
  如果沒有定義精度默認值為但是許多數據庫公司默認為所以請參考你的開發文檔
  時標只可以與其它TIMESTAMP類型的值相比較
  TIMESTAMP WITH TIME ZONE
  
  用法TIMESTAMP(精度)WITH TIME ZONE
  
  時標部分符合上述TIMESTAWP的規則
  精度代表秒的小數部分
  時區部分的要求和TIME WITH TIME ZONE一樣即時區符合UTC規范范圍在:到 +:之間
  總長度為個字符加上精度加上一個精度分隔符YYYYMMDD hh:mm:ssp
  它只能與其它TIMESTAMP WITH TIME ZONE類型的數據進行比較
  Interval
  
  Interval用於表示時間尺度例如你可以用操作符(將在下面進行解釋)去計算兩個日期間天數並加以保存
  
  各個公司在處理interval上有很大的不同——有些公司提供不同的度量單位如年或者分鐘而有些公司在根本就不支持intervalSQL標准的interval類型只提供一種子類型INTERVAL
  
  
  INTERVAL
  
  用法 INTERVAL (限定語)
  
  有兩種類型的interval一種為年份-月份即保存年份和月份(YYYYMM)一種為天-時間(DD HH:MM:SS)用來保存天數小時分鐘和秒
  限定語——在某些數據庫中interval前導精度(lead precision)——根據其值來指示interval采用年份-月份還是天-時間方式
  interval可正可負
  當與其它interval類型變量相比較時結果保持最大精度如有必要則補零
  INTERVAL全部由整數組成除了含有小數的秒之外
   年份-月份類型的interval變量只能與其它的年份-月份的interval變量進行比較天-時間類型也與此類似
  操作符
  
  操作結果類型
  
  當處理日期時間時時區保持不變——盡管有些數據庫為了比較而將其中的一個時區轉換為另一個存在一些操作關鍵字如OVERLAPS和EXTRACT它們用於操作和比較datetime類型數據然而不同的數據庫在這些操作關鍵字用法和支持方式上有著很大的不同
  
  OVERLAPS用於計算時間交疊的跨度其操作對象可以是兩個datetime也可以是一個datetime和一個intervalEXTRACT用於提取datetime或者interval類型數據的某個部分如在DATA類型數據中提取月份
  
  數據類型
  由於已建立的標准是為了各公司在現有基礎上實現實際上的數據類型的因此在具體限制參數和數據類型等方面你還是需要經常參考你的數據庫文檔

From:http://tw.wingwit.com/Article/program/SQLServer/201311/22163.html
    推薦文章
    Copyright © 2005-2013 電腦知識網 Computer Knowledge   All rights reserved.