1、 整數數據類型前端
整數數據類型是最經常使用的數據類型之一。 數據庫
1、INT (INTEGER)ide
INT (或INTEGER)數據類型存儲從-2的31次方 (-2 ,147 ,483 ,648) 到2的31次方-1 (2 ,147 ,483,647) 之間的全部正負整數。每一個INT 類型的數據按4 個字節存儲,其中1 位表示整數值的正負號,其它31 位表示整數值的長度和大小。 函數
2、SMALLINT工具
SMALLINT 數據類型存儲從-2的15次方( -32, 768) 到2的15次方-1( 32 ,767 )之間的全部正負整數。每一個SMALLINT 類型的數據佔用2 個字節的存儲空間,其中1 位表示整數值的正負號,其它15 位表示整數值的長度和大小。開發工具
3、TINYINT 編碼
TINYINT數據類型存儲從0 到255 之間的全部正整數。每一個TINYINT類型的數據佔用1 個字節的存儲空間。 spa
4、BIGINT指針
BIGINT 數據類型存儲從-2^63 (-9 ,223, 372, 036, 854, 775, 807) 到2^63-1( 9, 223, 372, 036 ,854 ,775, 807) 之間的全部正負整數。每一個BIGINT 類型的數據佔用8個字節的存儲空間。
2、 浮點數據類型code
浮點數據類型用於存儲十進制小數。浮點數值的數據在SQL Server 中採用上舍入(Round up 或稱爲只入不捨)方式進行存儲。所謂上舍入是指,當(且僅當)要舍入的數是一個非零數時,對其保留數字部分的最低有效位上的數值加1 ,並進行必要的進位。若一個數是上舍入數,其絕對值不會減小。如:對3.14159265358979 分別進行2 位和12位舍入,結果爲3.15 和3.141592653590。
1、REAL 數據類型
REAL數據類型可精確到第7 位小數,其範圍爲從-3.40E -38 到3.40E +38。 每一個REAL類型的數據佔用4 個字節的存儲空間。
2、FLOAT
FLOAT數據類型可精確到第15 位小數,其範圍爲從-1.79E -308 到1.79E +308。 每一個FLOAT 類型的數據佔用8 個字節的存儲空間。 FLOAT數據類型可寫爲FLOAT[ n ]的形式。n 指定FLOAT 數據的精度。n 爲1到15 之間的整數值。當n 取1 到7 時,其實是定義了一個REAL 類型的數據,系統用4 個字節存儲它;當n 取8 到15 時,系統認爲其是FLOAT 類型,用8 個字節存儲它。
3、DECIMAL
DECIMAL數據類型能夠提供小數所須要的實際存儲空間,但也有必定的限制,您能夠用2 到17 個字節來存儲從-10的38次方-1 到10的38次方-1 之間的數值。可將其寫爲DECIMAL[ p [s] ]的形式,p 和s 肯定了精確的比例和數位。其中p 表示可供存儲的值的總位數(不包括小數點),缺省值爲18; s 表示小數點後的位數,缺省值爲0。 例如:decimal (15 5),表示共有15 位數,其中整數10 位,小數5。 位表4-3 列出了各精確度所需的字節數之間的關係。
4、NUMERIC
NUMERIC數據類型與DECIMAL數據類型徹底相同。 注意:SQL Server 爲了和前端的開發工具配合,其所支持的數據精度默認最大爲28位。
3、 二進制數據類型
1、BINARY
BINARY 數據類型用於存儲二進制數據。其定義形式爲BINARY( n), n 表示數據的長度,取值爲1 到8000 。在使用時必須指定BINARY 類型數據的大小,至少應爲1 個字節。BINARY 類型數據佔用n+4 個字節的存儲空間。在輸入數據時必須在數據前加上字符「0X」 做爲二進制標識,如:要輸入「abc 」則應輸入「0xabc 」。若輸入的數據過長將會截掉其超出部分。若輸入的數據位數爲奇數,則會在起始符號「0X 」後添加一個0,如上述的「0xabc 」會被系統自動變爲「0x0abc」。
2、VARBINARY
VARBINARY數據類型的定義形式爲VARBINARY(n)。 它與BINARY 類型類似,n 的取值也爲1 到8000, 若輸入的數據過長,將會截掉其超出部分。不一樣的是VARBINARY數據類型具備變更長度的特性,由於VARBINARY數據類型的存儲長度爲實際數值長度+4個字節。當BINARY數據類型容許NULL 值時,將被視爲VARBINARY數據類型。
通常狀況下,因爲BINARY 數據類型長度固定,所以它比VARBINARY 類型的處理速度快。
4、 邏輯數據類型
BIT: BIT數據類型佔用1 個字節的存儲空間,其值爲0 或1 。若是輸入0 或1 之外的值,將被視爲1。 BIT 類型不能定義爲NULL 值(所謂NULL 值是指空值或無心義的值)。
5、 字符數據類型
字符數據類型是使用最多的數據類型。它能夠用來存儲各類字母、數字符號、特殊符號。通常狀況下,使用字符類型數據時須在其先後加上單引號’或雙引號」 。
1 CHAR
CHAR 數據類型的定義形式爲CHAR[ (n) ]。 以CHAR 類型存儲的每一個字符和符號佔一個字節的存儲空間。n 表示全部字符所佔的存儲空間,n 的取值爲1 到8000, 便可容納8000 個ANSI 字符。若不指定n 值,則系統默認值爲1。 若輸入數據的字符數小於n,則系統自動在其後添加空格來填滿設定好的空間。若輸入的數據過長,將會截掉其超出部分。
2、NCHAR
NCHAR數據類型的定義形式爲NCHAR[ (n) ]。 它與CHAR 類型類似。不一樣的是NCHAR數據類型n 的取值爲1 到4000。 由於NCHAR 類型採用UNICODE 標準字符集(CharacterSet)。 UNICODE 標準規定每一個字符佔用兩個字節的存儲空間,因此它比非UNICODE 標準的數據類型多佔用一倍的存儲空間。使用UNICODE 標準的好處是因其使用兩個字節作存儲單位,其一個存儲單位的容納量就大大增長了,能夠將全世界的語言文字都囊括在內,在一個數據列中就能夠同時出現中文、英文、法文、德文等,而不會出現編碼衝突。
3、VARCHAR
VARCHAR數據類型的定義形式爲VARCHAR [ (n) ]。 它與CHAR 類型類似,n 的取值也爲1 到8000, 若輸入的數據過長,將會截掉其超出部分。不一樣的是,VARCHAR數據類型具備變更長度的特性,由於VARCHAR數據類型的存儲長度爲實際數值長度,若輸入數據的字符數小於n ,則系統不會在其後添加空格來填滿設定好的空間。 通常狀況下,因爲CHAR 數據類型長度固定,所以它比VARCHAR 類型的處理速度快。
4、NVARCHAR
NVARCHAR數據類型的定義形式爲NVARCHAR[ (n) ]。 它與VARCHAR 類型類似。不一樣的是,NVARCHAR數據類型採用UNICODE 標準字符集(Character Set), n 的取值爲1 到4000。
6、文本和圖形數據類型
這類數據類型用於存儲大量的字符或二進制數據。
1、TEXT
TEXT數據類型用於存儲大量文本數據,其容量理論上爲1 到2的31次方-1 (2, 147, 483, 647)個字節,在實際應用時須要視硬盤的存儲空間而定。
SQL Server 2000 之前的版本中,數據庫中一個TEXT 對象存儲的其實是一個指針,它指向一個個以8KB (8192 個字節)爲單位的數據頁(Data Page)。 這些數據頁是動態增長並被邏輯連接起來的。在SQL Server 2000 中,則將TEXT 和IMAGE 類型的數據直接存放到表的數據行中,而不是存放到不一樣的數據頁中。 這就減小了用於存儲TEXT 和IMA- GE 類型的空間,並相應減小了磁盤處理這類數據的I/O 數量。
2 NTEXT
NTEXT數據類型與TEXT.類型類似不一樣的,是NTEXT 類型採用UNICODE 標準字符集(Character Set), 所以其理論容量爲230-1(1, 073, 741, 823)個字節。
3 IMAGE
IMAGE數據類型用於存儲大量的二進制數據Binary Data。 其理論容量爲2的31次方-1(2,147,483,647)個字節。其存儲數據的模式與TEXT 數據類型相同。一般用來存儲圖形等OLE Object Linking and Embedding,對象鏈接和嵌入)對象。在輸入數據時同BINARY數據類型同樣,必須在數據前加上字符「0X」做爲二進制標識
7、日期和時間數據類型
1 DATETIME
DATETIME 數據類型用於存儲日期和時間的結合體。它能夠存儲從公元1753 年1 月1 日零時起到公元9999 年12 月31 日23 時59 分59 秒之間的全部日期和時間,其精確度可達三百分之一秒,即3.33 毫秒。DATETIME 數據類型所佔用的存儲空間爲8 個字節。其中前4 個字節用於存儲1900 年1 月1 日之前或之後的天數,數值分正負,正數表示在此日期以後的日期,負數表示在此日期以前的日期。後4 個字節用於存儲今後日零時起所指定的時間通過的毫秒數。若是在輸入數據時省略了時間部分,則系統將12:00:00:000AM做爲時間缺省值:若是省略了日期部分,則系統將1900 年1 月1 日做爲日期缺省值。
2 SMALLDATETIME
SMALLDATETIME 數據類型與DATETIME 數據類型類似,但其日期時間範圍較小,爲從1900 年1 月1 日到2079 年6 月6:日精度較低,只能精確到分鐘,其分鐘個位上爲根據秒數四捨五入的值,即以30 秒爲界四捨五入。如:DATETIME 時間爲14:38:30.283時SMALLDATETIME 認爲是14:39:00 SMALLDATETIME 數據類型使用4 個字節存儲數據。其中前2 個字節存儲從基礎日期1900 年1 月1 日以來的天數,後兩個字節存儲此日零時起所指定的時間通過的分鐘數。
8、 貨幣數據類型
貨幣數據類型用於存儲貨幣值。在使用貨幣數據類型時,應在數據前加上貨幣符號,系統才能辨識其爲哪國的貨幣,若是不加貨幣符號,則默認爲「¥」。各貨幣符號如圖4-2所示。
1 MONEY
MONEY 數據類型的數據是一個有4 位小數的DECIMAL 值,其取值從-2的63次方(-922,337,203,685,477.5808到2的63次方-1(+922,337,203,685,477.5807),數據精度爲萬分之一貨幣單位。MONEY 數據類型使用8個字節存儲。
2 SMALLMONEY
SMALLMONEY數據類型相似於MONEY 類型,但其存儲的貨幣值範圍比MONEY數據類型小,其取值從-214,748.3648到+214,748.3647,存儲空間爲4 個字節。
9、 特定數據類型
SQL Server 中包含了一些用於數據存儲的特殊數據類型。
1 TIMESTAMP
TIMESTAMP數據類型提供數據庫範圍內的唯一值此類型至關於BINARY8或VARBINARY(8),但當它所定義的列在更新或插入數據行時,此列的值會被自動更新,一個計數值將自動地添加到此TIMESTAMP數據列中。每一個數據庫表中只能有一個TIMESTAMP數據列。若是創建一個名爲「TIMESTAMP」的列,則該列的類型將被自動設爲TIMESTAMP數據類型。
2 UNIQUEIDENTIFIER
UNIQUEIDENTIFIER 數據類型存儲一個16 位的二進制數字。此數字稱爲(GUIDGlobally Unique Identifier ,即全球唯一鑑別號)。此數字由SQLServer 的NEWID函數產生的全球唯一的編碼,在全球各地的計算機經由此函數產生的數字不會相同。
10、 用戶自定義數據類型
SYSNAME SYSNAME 數據類型是系統提供給用戶的,便於用戶自定義數據類型。它被定義爲NVARCHAR(128),即它可存儲128個UNICODE字符或256個通常字符。
以表格形式說明:
字段類型 |
描述 |
bit |
0或1的整型數字 |
int |
從-2^31(-2,147,483,648)到2^31(2,147,483,647)的整型數字 |
smallint |
從-2^15(-32,768)到2^15(32,767)的整型數字 |
tinyint |
從0到255的整型數字 |
|
|
decimal |
從-10^38到10^38-1的定精度與有效位數的數字 |
numeric |
decimal的同義詞 |
|
|
money |
從-2^63(-922,337,203,685,477.5808)到2^63-1(922,337,203,685,477.5807)的貨幣數據,最小貨幣單位千分之十 |
smallmoney |
從-214,748.3648到214,748.3647的貨幣數據,最小貨幣單位千分之十 |
|
|
float |
從-1.79E+308到1.79E+308可變精度的數字 |
real |
從-3.04E+38到3.04E+38可變精度的數字 |
|
|
datetime |
從1753年1月1日到9999年12日31的日期和時間數據,最小時間單位爲百分之三秒或3.33毫秒 |
smalldatetime |
從1900年1月1日到2079年6月6日的日期和時間數據,最小時間單位爲分鐘 |
|
|
timestamp |
時間戳,一個數據庫寬度的惟一數字 |
uniqueidentifier |
全球惟一標識符GUID |
|
|
char |
定長非Unicode的字符型數據,最大長度爲8000 |
varchar |
變長非Unicode的字符型數據,最大長度爲8000 |
text |
變長非Unicode的字符型數據,最大長度爲2^31-1(2G) |
|
|
nchar |
定長Unicode的字符型數據,最大長度爲8000 |
nvarchar |
變長Unicode的字符型數據,最大長度爲8000 |
ntext |
變長Unicode的字符型數據,最大長度爲2^31-1(2G) |
|
|
binary |
定長二進制數據,最大長度爲8000 |
varbinary |
變長二進制數據,最大長度爲8000 |
image |
變長二進制數據,最大長度爲2^31-1(2G) |