1. 程式人生 > >SQL Server比較常見資料型別詳解

SQL Server比較常見資料型別詳解

在SQL Server 中每個變數、引數、表示式等都有資料型別。系統提供的資料型別分為幾大類。

    其中,BIGINT、 SQL_VARIANT 和TABLE 是SQL Server 2000 中新增加的3 種資料型別。下面分類講述各種資料型別。

一、 整數資料型別

    整數資料型別是最常用的資料型別之一。

    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個位元組的儲存空間。 

二、 浮點資料型別

    浮點資料型別用於儲存十進位制小數。浮點數值的資料在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 位./* 

三、二進位制資料型別

    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 型別的處理速度快。

四、 邏輯資料型別

        BIT: BIT資料型別佔用1 個位元組的儲存空間,其值為0 或1 。如果輸入0 或1 以外的值,將被視為1。
        BIT 型別不能定義為NULL 值(所謂NULL 值是指空值或無意義的值)。

五、字元資料型別

    字元資料型別是使用最多的資料型別。它可以用來儲存各種字母、數字符號、特殊符號。一般情況下,使用字元型別資料時須在其前後加上單引號'或雙引號” 。

    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。

六、文字和圖形資料型別

    這類資料型別用於儲存大量的字元或二進位制資料。

    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”作為二進位制標識

七、 日期和時間資料型別

    1 DATETIME

        DATETIME 資料型別用於儲存日期和時間的結合體。它可以儲存從公元1753 年1 月1 日零時起到公元9999 年12 月31 日23 時59 分59 秒之間。