首頁(yè) > 開(kāi)發(fā) > 綜合 > 正文

數據類(lèi)型

2020-03-09 21:33:12
字體:
來(lái)源:轉載
供稿:網(wǎng)友


    在計算機中數據有兩種特征:類(lèi)型和長(cháng)度。所謂數據類(lèi)型就是以數據的表現方式和存儲方式來(lái)劃分的數據的種類(lèi)。
    在sql server 中每個(gè)變量、參數、表達式等都有數據類(lèi)型。系統提供的數據類(lèi)型分為幾大類(lèi),如表4-2 所示。

    其中,bigint、 sql_variant 和table 是sql server 2000 中新增加的3 種數據類(lèi)型。下面分類(lèi)講述各種數據類(lèi)型。

4.3.1 整數數據類(lèi)型
    整數數據類(lèi)型是最常用的數據類(lèi)型之一。
     1、int (integer)
int (或integer)數據類(lèi)型存儲從-2的31次方 (-2 ,147 ,483 ,648) 到2的31次方-1 (2 ,147 ,483,647) 之間的所有正負整數。每個(gè)int 類(lèi)型的數據按4 個(gè)字節存儲,其中1 位表示整數值的正負號,其它31 位表示整數值的長(cháng)度和大小。
     2、smallint
smallint 數據類(lèi)型存儲從-2的15次方( -32, 768) 到2的15次方-1( 32 ,767 )之間的所有正負整數。每個(gè)smallint 類(lèi)型的數據占用2 個(gè)字節的存儲空間,其中1 位表示整數值的正負號,其它15 位表示整數值的長(cháng)度和大小。
     3、tinyint
tinyint數據類(lèi)型存儲從0 到255 之間的所有正整數。每個(gè)tinyint類(lèi)型的數據占用1 個(gè)字節的存儲空間。
     4、bigint
bigint 數據類(lèi)型存儲從-2^63 (-9 ,223, 372, 036, 854, 775, 807) 到2^63-1( 9, 223, 372, 036 ,854 ,775, 807) 之間的所有正負整數。每個(gè)bigint 類(lèi)型的數據占用8個(gè)字節的存儲空間。

4.3.2 浮點(diǎn)數據類(lèi)型
    浮點(diǎn)數據類(lèi)型用于存儲十進(jìn)制小數。浮點(diǎn)數值的數據在sql server 中采用上舍入(round up 或稱(chēng)為只入不舍)方式進(jìn)行存儲。所謂上舍入是指,當(且僅當)要舍入的數是一個(gè)非零數時(shí),對其保留數字部分的最低有效位上的數值加1 ,并進(jìn)行必要的進(jìn)位。若一個(gè)數是上舍入數,其絕對值不會(huì )減少。如:對3.14159265358979 分別進(jìn)行2 位和12位舍入,結果為3.15 和3.141592653590。
     1、real 數據類(lèi)型
real數據類(lèi)型可精確到第7 位小數,其范圍為從-3.40e -38 到3.40e +38。 每個(gè)real類(lèi)型的數據占用4 個(gè)字節的存儲空間。
     2、float
float數據類(lèi)型可精確到第15 位小數,其范圍為從-1.79e -308 到1.79e +308。 每個(gè)float 類(lèi)型的數據占用8 個(gè)字節的存儲空間。 float數據類(lèi)型可寫(xiě)為float[ n ]的形式。n 指定float 數據的精度。n 為1到15 之間的整數值。當n 取1 到7 時(shí),實(shí)際上是定義了一個(gè)real 類(lèi)型的數據,系統用4 個(gè)字節存儲它;當n 取8 到15 時(shí),系統認為其是float 類(lèi)型,用8 個(gè)字節存儲它。
     3、decimal
decimal數據類(lèi)型可以提供小數所需要的實(shí)際存儲空間,但也有一定的限制,您可以用2 到17 個(gè)字節來(lái)存儲從-10的38次方-1 到10的38次方-1 之間的數值??蓪⑵鋵?xiě)為decimal[ p [s] ]的形式,p 和s 確定了精確的比例和數位。其中p 表示可供存儲的值的總位數(不包括小數點(diǎn)),缺省值為18; s 表示小數點(diǎn)后的位數,缺省值為0。 例如:decimal (15 5),表示共有15 位數,其中整數10 位,小數5。 位表4-3 列出了各精確度所需的字節數之間的關(guān)系。

     4、numeric
numeric數據類(lèi)型與decimal數據類(lèi)型完全相同。
注意:sql server 為了和前端的開(kāi)發(fā)工具配合,其所支持的數據精度默認最大為28位。但可以通過(guò)使用命令來(lái)執行sqlserver.exe程序以啟動(dòng)sql server,可改變默認精度。命令語(yǔ)法如下:sqlservr[/d master_device_path][/p precisim_leve1]
    例4-4: 用最大數據精度38 啟動(dòng)sql server
sqlservr /d c:/ mssql2000/data/master.dat /p38
/*在使用了/p 參數后,如果其后沒(méi)有指定具體的精度數值,則默認為38 位./*

4.3.3 二進(jìn)制數據類(lèi)型
     1、binary
binary 數據類(lèi)型用于存儲二進(jìn)制數據。其定義形式為binary( n), n 表示數據的長(cháng)度,取值為1 到8000 。在使用時(shí)必須指定binary 類(lèi)型數據的大小,至少應為1 個(gè)字節。binary 類(lèi)型數據占用n+4 個(gè)字節的存儲空間。在輸入數據時(shí)必須在數據前加上字符“0x” 作為二進(jìn)制標識,如:要輸入“abc ”則應輸入“0xabc ”。若輸入的數據過(guò)長(cháng)將會(huì )截掉其超出部分。若輸入的數據位數為奇數,則會(huì )在起始符號“0x ”后添加一個(gè)0,如上述的“0xabc ”會(huì )被系統自動(dòng)變?yōu)椤?x0abc”。
     2、varbinary
varbinary數據類(lèi)型的定義形式為varbinary(n)。 它與binary 類(lèi)型相似,n 的取值也為1 到8000, 若輸入的數據過(guò)長(cháng),將會(huì )截掉其超出部分。不同的是varbinary數據類(lèi)型具有變動(dòng)長(cháng)度的特性,因為varbinary數據類(lèi)型的存儲長(cháng)度為實(shí)際數值長(cháng)度+4個(gè)字節。當binary數據類(lèi)型允許null 值時(shí),將被視為varbinary數據類(lèi)型。
一般情況下,由于binary 數據類(lèi)型長(cháng)度固定,因此它比varbinary 類(lèi)型的處理速度快。

4.3.4 邏輯數據類(lèi)型
    bit: bit數據類(lèi)型占用1 個(gè)字節的存儲空間,其值為0 或1 。如果輸入0 或1 以外的值,將被視為1。 bit 類(lèi)型不能定義為null 值(所謂null 值是指空值或無(wú)意義的值)。

4.3.5 字符數據類(lèi)型
    字符數據類(lèi)型是使用最多的數據類(lèi)型。它可以用來(lái)存儲各種字母、數字符號、特殊符號。一般情況下,使用字符類(lèi)型數據時(shí)須在其前后加上單引號’或雙引號” 。
     1 char
char 數據類(lèi)型的定義形式為char[ (n) ]。 以char 類(lèi)型存儲的每個(gè)字符和符號占一個(gè)字節的存儲空間。n 表示所有字符所占的存儲空間,n 的取值為1 到8000, 即可容納8000 個(gè)ansi 字符。若不指定n 值,則系統默認值為1。 若輸入數據的字符數小于n,則系統自動(dòng)在其后添加空格來(lái)填滿(mǎn)設定好的空間。若輸入的數據過(guò)長(cháng),將會(huì )截掉其超出部分。
     2、nchar
nchar數據類(lèi)型的定義形式為nchar[ (n) ]。 它與char 類(lèi)型相似。不同的是nchar數據類(lèi)型n 的取值為1 到4000。 因為nchar 類(lèi)型采用unicode 標準字符集(characterset)。 unicode 標準規定每個(gè)字符占用兩個(gè)字節的存儲空間,所以它比非unicode 標準的數據類(lèi)型多占用一倍的存儲空間。使用unicode 標準的好處是因其使用兩個(gè)字節做存儲單位,其一個(gè)存儲單位的容納量就大大增加了,可以將全世界的語(yǔ)言文字都囊括在內,在一個(gè)數據列中就可以同時(shí)出現中文、英文、法文、德文等,而不會(huì )出現編碼沖突。
     3、varchar
varchar數據類(lèi)型的定義形式為varchar [ (n) ]。 它與char 類(lèi)型相似,n 的取值也為1 到8000, 若輸入的數據過(guò)長(cháng),將會(huì )截掉其超出部分。不同的是,varchar數據類(lèi)型具有變動(dòng)長(cháng)度的特性,因為varchar數據類(lèi)型的存儲長(cháng)度為實(shí)際數值長(cháng)度,若輸入數據的字符數小于n ,則系統不會(huì )在其后添加空格來(lái)填滿(mǎn)設定好的空間。
一般情況下,由于char 數據類(lèi)型長(cháng)度固定,因此它比varchar 類(lèi)型的處理速度快。
     4、nvarchar
nvarchar數據類(lèi)型的定義形式為nvarchar[ (n) ]。 它與varchar 類(lèi)型相似。不同的是,nvarchar數據類(lèi)型采用unicode 標準字符集(character set), n 的取值為1 到4000。

4.3.6 文本和圖形數據類(lèi)型
    這類(lèi)數據類(lèi)型用于存儲大量的字符或二進(jìn)制數據。
     1、text
text數據類(lèi)型用于存儲大量文本數據,其容量理論上為1 到2的31次方-1 (2, 147, 483, 647)個(gè)字節,在實(shí)際應用時(shí)需要視硬盤(pán)的存儲空間而定。
sql server 2000 以前的版本中,數據庫中一個(gè)text 對象存儲的實(shí)際上是一個(gè)指針,它指向一個(gè)個(gè)以8kb (8192 個(gè)字節)為單位的數據頁(yè)(data page)。 這些數據頁(yè)是動(dòng)態(tài)增加并被邏輯鏈接起來(lái)的。在sql server 2000 中,則將text 和image 類(lèi)型的數據直接存放到表的數據行中,而不是存放到不同的數據頁(yè)中。 這就減少了用于存儲text 和ima- ge 類(lèi)型的空間,并相應減少了磁盤(pán)處理這類(lèi)數據的i/o 數量。
    2 ntext
ntext數據類(lèi)型與text.類(lèi)型相似不同的,是ntext 類(lèi)型采用unicode 標準字符集(character set), 因此其理論容量為230-1(1, 073, 741, 823)個(gè)字節。
    3 image
image數據類(lèi)型用于存儲大量的二進(jìn)制數據binary data。 其理論容量為2的31次方-1(2,147,483,647)個(gè)字節。其存儲數據的模式與text 數據類(lèi)型相同。通常用來(lái)存儲圖形等ole object linking and embedding,對象連接和嵌入)對象。在輸入數據時(shí)同binary數據類(lèi)型一樣,必須在數據前加上字符“0x”作為二進(jìn)制標識

4.3.7 日期和時(shí)間數據類(lèi)型
    1 datetime
datetime 數據類(lèi)型用于存儲日期和時(shí)間的結合體。它可以存儲從公元1753 年1 月1 日零時(shí)起到公元9999 年12 月31 日23 時(shí)59 分59 秒之間的所有日期和時(shí)間,其精確度可達三百分之一秒,即3.33 毫秒。datetime 數據類(lèi)型所占用的存儲空間為8 個(gè)字節。其中前4 個(gè)字節用于存儲1900 年1 月1 日以前或以后的天數,數值分正負,正數表示在此日期之后的日期,負數表示在此日期之前的日期。后4 個(gè)字節用于存儲從此日零時(shí)起所指定的時(shí)間經(jīng)過(guò)的毫秒數。如果在輸入數據時(shí)省略了時(shí)間部分,則系統將12:00:00:000am作為時(shí)間缺省值:如果省略了日期部分,則系統將1900 年1 月1 日作為日期缺省值。
    2 smalldatetime
smalldatetime 數據類(lèi)型與datetime 數堇嘈拖嗨?,但其日浦o奔浞段ы閑?,为?900 年1 月1 日到2079 年6 月6:日精度較低,只能精確到分鐘,其分鐘個(gè)位上為根據秒數四舍五入的值,即以30 秒為界四舍五入。如:datetime 時(shí)間為14:38:30.283
時(shí)smalldatetime 認為是14:39:00 smalldatetime 數據類(lèi)型使用4 個(gè)字節存儲數據。其中前2 個(gè)字節存儲從基礎日期1900 年1 月1 日以來(lái)的天數,后兩個(gè)字節存儲此日零時(shí)起所指定的時(shí)間經(jīng)過(guò)的分鐘數。
    下面介紹日期和時(shí)間的輸入格式
    日期輸入格式
    日期的輸入格式很多大致可分為三類(lèi):

  • 英文+數字格式
    此類(lèi)格式中月份可用英文全名或縮寫(xiě),且不區分大小寫(xiě);年和月日之間可不用逗號;
    年份可為4 位或2 位;當其為兩位時(shí),若值小于50 則視為20xx 年,若大于或等于50 則
    視為19xx 年;若日部分省略,則視為當月的1號。以下格式均為正確的日期格式:
    june 21 2000 oct 1 1999 january 2000 2000 february
    2000 may 1 2000 1 sep 99 june july 00
  • 數字+分隔符格式
    允許把斜杠(/)、連接符(-)和小數點(diǎn)(.)作為用數字表示的年、月、日之間的分
    隔符。如:
    ymd:2000/6/22 2000-6-22 2000.6.22
    mdy:3/5/2000 3-5-2000 3.5.2000
    dmy:31/12/1999 31-12-1999 31.12.2000
  • 純數字格式
    純數字格式是以連續的4 位6、位或8 位數字來(lái)表示日期。如果輸入的是6 位或8 位
    數字,系統將按年、月、日來(lái)識別,即ymd 格式,并且月和日都是用兩位數字來(lái)表示:
    如果輸入的數字是4 位數,系統認為這4 位數代表年份,其月份和日缺省為此年度的1 月
    1 日。如:
    20000601---2000 年6 月1 日 991212---1999 年12 月12 日 1998---1998 年
????

時(shí)間輸入格式
在輸入時(shí)間時(shí)必須按“小時(shí)、分鐘、秒、毫秒”的順序來(lái)輸入。在其間用冒號“:”隔開(kāi)。但可將毫秒部分用小數點(diǎn)“.” 分,隔其后第一位數字代表十分之一秒,第二位數字代表百分之一秒,第三位數字代表千分之一秒。當使用12 小時(shí)制時(shí)用am。am 和pm(pm)分別指定時(shí)間是午前或午后,若不指定,系統默認為am。am 與pm 均不區分大小寫(xiě)。如:
    3:5:7.2pm---下午3 時(shí)5 分7 秒200 毫秒
    10:23:5.123am---上午10 時(shí)23 分5 秒123 毫秒
    可以使用set dateformat 命令來(lái)設定系統默認的日期-時(shí)間格式。

4.3.8 貨幣數據類(lèi)型
貨幣數據類(lèi)型用于存儲貨幣值。在使用貨幣數據類(lèi)型時(shí),應在數據前加上貨幣符號,系統才能辨識其為哪國的貨幣,如果不加貨幣符號,則默認為“¥”。各貨幣符號如圖4-2所示。
    1 money
money 數據類(lèi)型的數據是一個(gè)有4 位小數的decimal 值,其取值從-2的63次方(-922,337,203,685,477.5808到2的63次方-1(+922,337,203,685,477.5807),數據精度為萬(wàn)分之一貨幣單位。money 數據類(lèi)型使用8個(gè)字節存儲。

    2 smallmoney
smallmoney數據類(lèi)型類(lèi)似于money 類(lèi)型,但其存儲的貨幣值范圍比money數據類(lèi)型小,其取值從-214,748.3648到+214,748.3647,存儲空間為4 個(gè)字節。

4.3.9 特定數據類(lèi)型
sql server 中包含了一些用于數據存儲的特殊數據類(lèi)型。
    1 timestamp
timestamp數據類(lèi)型提供數據庫范圍內的惟一值此類(lèi)型相當于binary8或varbinary(8),但當它所定義的列在更新或插入數據行時(shí),此列的值會(huì )被自動(dòng)更新,一個(gè)計數值將自動(dòng)地添加到此timestamp數據列中。每個(gè)數據庫表中只能有一個(gè)timestamp數據列。如果建立一個(gè)名為“timestamp”的列,則該列的類(lèi)型將被自動(dòng)設為timestamp數據類(lèi)型。

    2 uniqueidentifier
uniqueidentifier 數據類(lèi)型存儲一個(gè)16 位的二進(jìn)制數字。此數字稱(chēng)為(guidglobally unique identifier ,即全球惟一鑒別號)。此數字由sqlserver 的newid函數產(chǎn)生的全球惟一的編碼,在全球各地的計算機經(jīng)由此函數產(chǎn)生的數字不會(huì )相同。

4.3.10 用戶(hù)自定義數據類(lèi)型
sysname sysname 數據類(lèi)型是系統提供給用戶(hù)的,便于用戶(hù)自定義數據類(lèi)型。它被定義為nvarchar(128),即它可存儲128個(gè)unicode字符或256個(gè)一般字符。其具體使用方法請參見(jiàn)第7章“管理數據庫表”中的“自定義數據類(lèi)型”章節。

4.3.11 新數據類(lèi)型
sql server 2000 中增加了3 種數據類(lèi)型:bigint、sql_variant和table。其中bigint數據類(lèi)型已在整數類(lèi)型中介紹,下面介紹其余兩種:
    1 sql_variant
sql_variant數據類(lèi)型可以存儲除文本、圖形數據(text、ntext、image)和timestamp類(lèi)型數據外的其它任何合法的sql server數據。此數據類(lèi)型大大方便了sql server的開(kāi)發(fā)工作。
    2 table
table 數據類(lèi)型用于存儲對表或視圖處理后的結果集。這一新類(lèi)型使得變量可以存儲一個(gè)表,從而使函數或過(guò)程返回查詢(xún)結果更加方便快、捷其、使用請參見(jiàn)第13章“游標、視圖和自定義函數”。

上一篇:Transact-SQL 語(yǔ)言概述

下一篇:SQL 變量

發(fā)表評論 共有條評論
用戶(hù)名: 密碼:
驗證碼: 匿名發(fā)表