濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQL Server比較常見數(shù)據(jù)類型詳解

SQL Server比較常見數(shù)據(jù)類型詳解

熱門標簽:如何在地圖標注自己店鋪 地圖標注一個圓圈怎么用 寧波人工外呼系統(tǒng)有效果嗎 電銷機器人被曝光 真人語音電銷機器人 怎樣把地圖標注導入公司地址 廣州人工電銷機器人費用 洛陽外呼系統(tǒng)平臺 400外呼系統(tǒng)合法

   在SQL Server 中每個變量、參數(shù)、表達式等都有數(shù)據(jù)類型。系統(tǒng)提供的數(shù)據(jù)類型分為幾大類,如表4-2 所示。

    其中,BIGINT、 SQL_VARIANT 和TABLE 是SQL Server 2000 中新增加的3 種數(shù)據(jù)類型。下面分類講述各種數(shù)據(jù)類型。

一、 整數(shù)數(shù)據(jù)類型

    整數(shù)數(shù)據(jù)類型是最常用的數(shù)據(jù)類型之一。

    1、INT (INTEGER)

        INT (或INTEGER)數(shù)據(jù)類型存儲從-2的31次方 (-2 ,147 ,483 ,648) 到2的31次方-1 (2 ,147 ,483,647) 之間的所有正負整數(shù)。

        每個INT 類型的數(shù)據(jù)按4 個字節(jié)存儲,其中1 位表示整數(shù)值的正負號,其它31 位表示整數(shù)值的長度和大小。

    2、SMALLINT

        SMALLINT 數(shù)據(jù)類型存儲從-2的15次方( -32, 768) 到2的15次方-1( 32 ,767 )之間的所有正負整數(shù)。

        每個SMALLINT 類型的數(shù)據(jù)占用2 個字節(jié)的存儲空間,其中1 位表示整數(shù)值的正負號,其它15 位表示整數(shù)值的長度和大小。

    3、TINYINT

        TINYINT數(shù)據(jù)類型存儲從0 到255 之間的所有正整數(shù)。每個TINYINT類型的數(shù)據(jù)占用1 個字節(jié)的存儲空間。

    4、BIGINT

        BIGINT 數(shù)據(jù)類型存儲從-2^63 (-9 ,223, 372, 036, 854, 775, 807) 到2^63-1( 9, 223, 372, 036 ,854 ,775, 807) 之間的所有正負整數(shù)。

        每個BIGINT 類型的數(shù)據(jù)占用8個字節(jié)的存儲空間。 

二、 浮點數(shù)據(jù)類型

    浮點數(shù)據(jù)類型用于存儲十進制小數(shù)。浮點數(shù)值的數(shù)據(jù)在SQL Server 中采用上舍入(Round up 或稱為只入不舍)方式進行存儲。

    所謂上舍入是指,當(且僅當)要舍入的數(shù)是一個非零數(shù)時,對其保留數(shù)字部分的最低有效位上的數(shù)值加1 ,并進行必要的進位。若一個數(shù)是上舍入數(shù),其絕對值不會減少。

    如:對3.14159265358979 分別進行2 位和12位舍入,結果為3.15 和3.141592653590。

   1、REAL 數(shù)據(jù)類型

        REAL數(shù)據(jù)類型可精確到第7 位小數(shù),其范圍為從-3.40E -38 到3.40E +38。 每個REAL類型的數(shù)據(jù)占用4 個字節(jié)的存儲空間。

    2、FLOAT

        FLOAT 數(shù)據(jù)類型可精確到第15 位小數(shù),其范圍為從-1.79E -308 到1.79E +308。 每個FLOAT 類型的數(shù)據(jù)占用8 個字節(jié)的存儲空間。 

        FLOAT數(shù)據(jù)類型可寫為FLOAT[ n ]的形式。n 指定FLOAT 數(shù)據(jù)的精度。n 為1到15 之間的整數(shù)值。當n 取1 到7 時,實際上是定義了一個REAL 類型的數(shù)據(jù),系統(tǒng)用4 個字節(jié)存儲它;
        當n 取8 到15 時,系統(tǒng)認為其是FLOAT 類型,用8 個字節(jié)存儲它。

    3、DECIMAL

        DECIMAL數(shù)據(jù)類型可以提供小數(shù)所需要的實際存儲空間,但也有一定的限制,您可以用2 到17 個字節(jié)來存儲從-10的38次方-1 到10的38次方-1 之間的數(shù)值。

        可將其寫為DECIMAL[ p [s] ]的形式,p 和s 確定了精確的比例和數(shù)位。其中p 表示可供存儲的值的總位數(shù)(不包括小數(shù)點),缺省值為18; s 表示小數(shù)點后的位數(shù),缺省值為0。

        例如:decimal (15 5),表示共有15 位數(shù),其中整數(shù)10 位,小數(shù)5。   

    4、NUMERIC

        NUMERIC數(shù)據(jù)類型與DECIMAL數(shù)據(jù)類型完全相同。
    注意:SQL Server 為了和前端的開發(fā)工具配合,其所支持的數(shù)據(jù)精度默認最大為28位。但可以通過使用命令來執(zhí)行sqlserver.exe程序以啟動SQL Server,可改變默認精度。

    命令語法如下:

        SQLSERVR[/D master_device_path][/P precisim_leve1]

    例4-4: 用最大數(shù)據(jù)精度38 啟動SQL Server

        sqlservr /d c:\ Mssql2000\data\master.dat /p38

        /*在使用了/P 參數(shù)后,如果其后沒有指定具體的精度數(shù)值,則默認為38 位./* 

三、二進制數(shù)據(jù)類型

    1、BINARY

        BINARY 數(shù)據(jù)類型用于存儲二進制數(shù)據(jù)。其定義形式為BINARY( n), n 表示數(shù)據(jù)的長度,取值為1 到8000 。

        在使用時必須指定BINARY 類型數(shù)據(jù)的大小,至少應為1 個字節(jié)。BINARY 類型數(shù)據(jù)占用n+4 個字節(jié)的存儲空間。

        在輸入數(shù)據(jù)時必須在數(shù)據(jù)前加上字符“0X” 作為二進制標識,如:要輸入“abc ”則應輸入“0xabc ”。

        若輸入的數(shù)據(jù)過長將會截掉其超出部分。若輸入的數(shù)據(jù)位數(shù)為奇數(shù),則會在起始符號“0X ”后添加一個0,如上述的“0xabc ”會被系統(tǒng)自動變?yōu)椤?x0abc”。

    2、VARBINARY

        VARBINARY 數(shù)據(jù)類型的定義形式為VARBINARY(n)。 它與BINARY 類型相似,n 的取值也為1 到8000,若輸入的數(shù)據(jù)過長,將會截掉其超出部分。

        不同的是VARBINARY數(shù)據(jù)類型具有變動長度的特性,因為VARBINARY數(shù)據(jù)類型的存儲長度為實際數(shù)值長度+4個字節(jié)。當BINARY數(shù)據(jù)類型允許NULL 值時,將被視為VARBINARY數(shù)據(jù)類型。

        一般情況下,由于BINARY 數(shù)據(jù)類型長度固定,因此它比VARBINARY 類型的處理速度快。

四、 邏輯數(shù)據(jù)類型

        BIT: BIT數(shù)據(jù)類型占用1 個字節(jié)的存儲空間,其值為0 或1 。如果輸入0 或1 以外的值,將被視為1。
        BIT 類型不能定義為NULL 值(所謂NULL 值是指空值或無意義的值)。

五、字符數(shù)據(jù)類型

    字符數(shù)據(jù)類型是使用最多的數(shù)據(jù)類型。它可以用來存儲各種字母、數(shù)字符號、特殊符號。一般情況下,使用字符類型數(shù)據(jù)時須在其前后加上單引號'或雙引號” 。

    1 CHAR

        CHAR 數(shù)據(jù)類型的定義形式為CHAR[ (n) 。 以CHAR 類型存儲的每個字符和符號占一個字節(jié)的存儲空間。n 表示所有字符所占的存儲空間,n 的取值為1 到8000, 

        即可容納8000 個ANSI 字符。若不指定n 值,則系統(tǒng)默認值為1。若輸入數(shù)據(jù)的字符數(shù)小于n,則系統(tǒng)自動在其后添加空格來填滿設定好的空間。若輸入的數(shù)據(jù)過長,將會截掉其超出部分。

    2、NCHAR

        NCHAR 數(shù)據(jù)類型的定義形式為NCHAR[ (n)]。 它與CHAR 類型相似。不同的是NCHAR數(shù)據(jù)類型n 的取值為1 到4000。 因為NCHAR 類型采用UNICODE 標準字符集(CharacterSet)。 

        UNICODE 標準規(guī)定每個字符占用兩個字節(jié)的存儲空間,所以它比非UNICODE 標準的數(shù)據(jù)類型多占用一倍的存儲空間。使用UNICODE 標準的好處是因其使用兩個字節(jié)做存儲單位, 其一個存儲單位的容納量就大大增加了,可以將全世界的語言文字都囊括在內(nèi),在一個數(shù)據(jù)列中就可以同時出現(xiàn)中文、英文、法文、德文等,而不會出現(xiàn)編碼沖突。

    3、VARCHAR

        VARCHAR數(shù)據(jù)類型的定義形式為VARCHARn)。 它與CHAR 類型相似,n 的取值也為1 到8000,若輸入的數(shù)據(jù)過長,將會截掉其超出部分。
        不同的是,VARCHAR數(shù)據(jù)類型具有變動長度的特性,因為VARCHAR數(shù)據(jù)類型的存儲長度為實際數(shù)值長度,若輸入數(shù)據(jù)的字符數(shù)小于n ,則系統(tǒng)不會在其后添加空格來填滿設定好的空間。
        一般情況下,由于CHAR 數(shù)據(jù)類型長度固定,因此它比VARCHAR 類型的處理速度快。

   4、NVARCHAR

        NVARCHAR數(shù)據(jù)類型的定義形式為NVARCHAR[ (n) ]。 它與VARCHAR 類型相似。不同的是,NVARCHAR數(shù)據(jù)類型采用UNICODE 標準字符集(Character Set), n 的取值為1 到4000。

六、文本和圖形數(shù)據(jù)類型

    這類數(shù)據(jù)類型用于存儲大量的字符或二進制數(shù)據(jù)。

    1、TEXT

        TEXT數(shù)據(jù)類型用于存儲大量文本數(shù)據(jù),其容量理論上為1 到2的31次方-1 (2, 147, 483, 647)個字節(jié),在實際應用時需要視硬盤的存儲空間而定。

        SQL Server 2000 以前的版本中,數(shù)據(jù)庫中一個TEXT 對象存儲的實際上是一個指針,它指向一個個以8KB (8192 個字節(jié))為單位的數(shù)據(jù)頁(Data Page)。 

        這些數(shù)據(jù)頁是動態(tài)增加并被邏輯鏈接起來的。在SQL Server 2000 中,則將TEXT 和IMAGE 類型的數(shù)據(jù)直接存放到表的數(shù)據(jù)行中,而不是存放到不同的數(shù)據(jù)頁中。
        這就減少了用于存儲TEXT 和IMA- GE 類型的空間,并相應減少了磁盤處理這類數(shù)據(jù)的I/O 數(shù)量。

    2、 NTEXT

       NTEXT數(shù)據(jù)類型與TEXT.類型相似不同的,是NTEXT 類型采用UNICODE 標準字符集(Character Set), 因此其理論容量為230-1(1, 073, 741, 823)個字節(jié)。 

   3、 IMAGE

        IMAGE 數(shù)據(jù)類型用于存儲大量的二進制數(shù)據(jù)Binary Data。其理論容量為2的31次方-1(2,147,483,647)個字節(jié)。其存儲數(shù)據(jù)的模式與TEXT 數(shù)據(jù)類型相同。

        通常用來存儲圖形等OLE Object Linking and Embedding,對象連接和嵌入)對象。在輸入數(shù)據(jù)時同BINARY數(shù)據(jù)類型一樣,必須在數(shù)據(jù)前加上字符“0X”作為二進制標識

七、 日期和時間數(shù)據(jù)類型

    1 DATETIME

        DATETIME 數(shù)據(jù)類型用于存儲日期和時間的結合體。它可以存儲從公元1753 年1 月1 日零時起到公元9999 年12 月31 日23 時59 分59 秒之間。

以上就是本文的全部敘述,希望大家喜歡。

您可能感興趣的文章:
  • 詳解SQL Server中的數(shù)據(jù)類型
  • 詳解MySQL數(shù)據(jù)類型int(M)中M的含義
  • mysql存儲引擎和數(shù)據(jù)類型(二)
  • Java數(shù)據(jù)類型與MySql數(shù)據(jù)類型對照表
  • SQL Server數(shù)據(jù)類型轉換方法
  • SQLite教程(七):數(shù)據(jù)類型詳解
  • SQL Server數(shù)據(jù)類型char、nchar、varchar、nvarchar的區(qū)別淺析
  • sql使用cast進行數(shù)據(jù)類型轉換示例
  • SQL2005中char nchar varchar nvarchar數(shù)據(jù)類型的區(qū)別和使用環(huán)境講解
  • SQL的常用數(shù)據(jù)類型列表詳解

標簽:阿里 通遼 南京 廣安 陜西 馬鞍山 福建 河北

巨人網(wǎng)絡通訊聲明:本文標題《SQL Server比較常見數(shù)據(jù)類型詳解》,本文關鍵詞  SQL,Server,比較,常見,數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server比較常見數(shù)據(jù)類型詳解》相關的同類信息!
  • 本頁收集關于SQL Server比較常見數(shù)據(jù)類型詳解的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    桃江县| 阿瓦提县| 威海市| 霍邱县| 宜君县| 博兴县| 万载县| 平塘县| 新沂市| 长春市| 广昌县| 商洛市| 永和县| 大庆市| 宜都市| 牡丹江市| 旬阳县| 齐齐哈尔市| 阿瓦提县| 通许县| 闽清县| 南木林县| 日土县| 石城县| 太仆寺旗| 特克斯县| 精河县| 鄂托克旗| 关岭| 横山县| 平邑县| 大城县| 昭苏县| 新平| 四平市| 新巴尔虎左旗| 潜山县| 贵阳市| 郎溪县| 汾阳市| 辽宁省|