SQL Server比擬罕見數據類型詳解。本站提示廣大學習愛好者:(SQL Server比擬罕見數據類型詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是SQL Server比擬罕見數據類型詳解正文
在SQL Server 中每一個變量、參數、表達式等都稀有據類型。體系供給的數據類型分為幾年夜類,如表4-2 所示。
個中,BIGINT、 SQL_VARIANT 和TABLE 是SQL Server 2000 中新增長的3 種數據類型。上面分類講述各類數據類型。
1、 整數數據類型
整數數據類型是最經常使用的數據類型之一。
1、INT (INTEGER)
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 個字節的存儲空間。
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、 浮點數據類型
浮點數據類型用於存儲十進制小數。浮點數值的數據在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、NUMERIC
NUMERIC數據類型與DECIMAL數據類型完整雷同。
留意:SQL Server 為了和前真個開辟對象合營,其所支撐的數據精度默許最年夜為28位。但可以經由過程應用敕令來履行sqlserver.exe法式以啟動SQL Server,可轉變默許精度。
敕令語法以下:
SQLSERVR[/D master_device_path][/P precisim_leve1]
例4-4: 用最年夜數據精度38 啟動SQL Server
sqlservr /d c:\ Mssql2000\data\master.dat /p38
/*在應用了/P 參數後,假如厥後沒有指定詳細的精度數值,則默許為38 位./*
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數據類型的界說情勢為VARCHARn)。 它與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 秒之間。
以上就是本文的全體論述,願望年夜家愛好。