4.3.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.3.4 邏輯數據類型
bit: bit數據類型占用1 個字節的存儲空間,其值為0 或1 。如果輸入0 或1 以外的值,將被視為1。 bit 類型不能定義為null 值(所謂null 值是指空值或無意義的值)。
4.3.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。
4.3.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”作為二進制標識
4.3.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 數堇嘈拖嗨?,但其日浦o奔浞段ы閑?,为?900 年1 月1 日到2079 年6 月6:日精度較低,只能精確到分鐘,其分鐘個位上為根據秒數四舍五入的值,即以30 秒為界四舍五入。如:datetime 時間為14:38:30.283
時smalldatetime 認為是14:39:00 smalldatetime 數據類型使用4 個字節存儲數據。其中前2 個字節存儲從基礎日期1900 年1 月1 日以來的天數,后兩個字節存儲此日零時起所指定的時間經過的分鐘數。
下面介紹日期和時間的輸入格式
日期輸入格式
日期的輸入格式很多大致可分為三類:
時間輸入格式
在輸入時間時必須按“小時、分鐘、秒、毫秒”的順序來輸入。在其間用冒號“:”隔開。但可將毫秒部分用小數點“.” 分,隔其后第一位數字代表十分之一秒,第二位數字代表百分之一秒,第三位數字代表千分之一秒。當使用12 小時制時用am。am 和pm(pm)分別指定時間是午前或午后,若不指定,系統默認為am。am 與pm 均不區分大小寫。如:
3:5:7.2pm---下午3 時5 分7 秒200 毫秒
10:23:5.123am---上午10 時23 分5 秒123 毫秒
可以使用set dateformat 命令來設定系統默認的日期-時間格式。
4.3.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 個字節。
4.3.9 特定數據類型
sql server 中包含了一些用于數據存儲的特殊數據類型。
1 timestamp
timestamp數據類型提供數據庫范圍內的惟一值此類型相當于binary8或varbinary(8),但當它所定義的列在更新或插入數據行時,此列的值會被自動更新,一個計數值將自動地添加到此timestamp數據列中。每個數據庫表中只能有一個timestamp數據列。如果建立一個名為“timestamp”的列,則該列的類型將被自動設為timestamp數據類型。
2 uniqueidentifier
uniqueidentifier 數據類型存儲一個16 位的二進制數字。此數字稱為(guidglobally unique identifier ,即全球惟一鑒別號)。此數字由sqlserver 的newid函數產生的全球惟一的編碼,在全球各地的計算機經由此函數產生的數字不會相同。
4.3.10 用戶自定義數據類型
sysname sysname 數據類型是系統提供給用戶的,便于用戶自定義數據類型。它被定義為nvarchar(128),即它可存儲128個unicode字符或256個一般字符。其具體使用方法請參見第7章“管理數據庫表”中的“自定義數據類型”章節。
4.3.11 新數據類型
sql server 2000 中增加了3 種數據類型:bigint、sql_variant和table。其中bigint數據類型已在整數類型中介紹,下面介紹其余兩種:
1 sql_variant
sql_variant數據類型可以存儲除文本、圖形數據(text、ntext、image)和timestamp類型數據外的其它任何合法的sql server數據。此數據類型大大方便了sql server的開發工作。
2 table
table 數據類型用于存儲對表或視圖處理后的結果集。這一新類型使得變量可以存儲一個表,從而使函數或過程返回查詢結果更加方便快、捷其、使用請參見第13章“游標、視圖和自定義函數”。
新聞熱點
疑難解答