SQL的常用數(shù)據(jù)類(lèi)型列表詳解
| 數(shù)據(jù)類(lèi)型 | 描述 |
|---|---|
| CHARACTER(n) | 字符/字符串。固定長(zhǎng)度 n。 |
| VARCHAR(n) 或 CHARACTER VARYING(n) |
字符/字符串??勺冮L(zhǎng)度。最大長(zhǎng)度 n。 |
| BINARY(n) | 二進(jìn)制串。固定長(zhǎng)度 n。 |
| BOOLEAN | 存儲(chǔ) TRUE 或 FALSE 值 |
| VARBINARY(n) 或 BINARY VARYING(n) |
二進(jìn)制串??勺冮L(zhǎng)度。最大長(zhǎng)度 n。 |
| INTEGER(p) | 整數(shù)值(沒(méi)有小數(shù)點(diǎn))。精度 p。 |
| SMALLINT | 整數(shù)值(沒(méi)有小數(shù)點(diǎn))。精度 5。 存儲(chǔ)數(shù)據(jù)的范圍是從-2的15次方(-32768)到2的15次方-1(32767),占用2個(gè)字節(jié)的儲(chǔ)存空間。 |
| INTEGER | 整數(shù)值(沒(méi)有小數(shù)點(diǎn))。精度 10。 存儲(chǔ)數(shù)據(jù)的范圍是-2的31次方到2的31次方-1,占用4個(gè)字節(jié)的儲(chǔ)存空間。 |
| BIGINT | 整數(shù)值(沒(méi)有小數(shù)點(diǎn))。精度 19。 |
| DECIMAL(p,s) | 精確數(shù)值,精度 p,小數(shù)點(diǎn)后位數(shù) s。例如:decimal(5,2) 是一個(gè)小數(shù)點(diǎn)前有 3 位數(shù)小數(shù)點(diǎn)后有 2 位數(shù)的數(shù)字。 |
| NUMERIC(p,s) | 精確數(shù)值,精度 p,小數(shù)點(diǎn)后位數(shù) s。(與 DECIMAL 相同) |
| FLOAT(p) | 近似數(shù)值,尾數(shù)精度 p。一個(gè)采用以 10 為基數(shù)的指數(shù)計(jì)數(shù)法的浮點(diǎn)數(shù)。該類(lèi)型的 size 參數(shù)由一個(gè)指定最小精度的單一數(shù)字組成。 |
| REAL | 近似數(shù)值,尾數(shù)精度 7。 |
| FLOAT | 近似數(shù)值,尾數(shù)精度 16。 |
| DOUBLE PRECISION | 近似數(shù)值,尾數(shù)精度 16。 |
| DATE | 存儲(chǔ)年、月、日的值。 |
| TIME | 存儲(chǔ)小時(shí)、分、秒的值。 |
| TIMESTAMP | 存儲(chǔ)年、月、日、小時(shí)、分、秒的值。 |
| INTERVAL | 由一些整數(shù)字段組成,代表一段時(shí)間,取決于區(qū)間的類(lèi)型。 |
| ARRAY | 元素的固定長(zhǎng)度的有序集合 |
| MULTISET | 元素的可變長(zhǎng)度的無(wú)序集合 |
| XML | 存儲(chǔ) XML 數(shù)據(jù) |
其中標(biāo)紅的是在建表時(shí)常用的數(shù)據(jù)類(lèi)型。
數(shù)據(jù)類(lèi)型的名稱(chēng)在不同數(shù)據(jù)庫(kù)平臺(tái)中有一些區(qū)別,在SQL Server和MY SQL中(或者還有其他平臺(tái))數(shù)值型還有一個(gè)tinyint的類(lèi)型(范圍從0到255)。
應(yīng)該注意根據(jù)實(shí)際情況選用不同的數(shù)據(jù)類(lèi)型。
一、定義數(shù)據(jù)長(zhǎng)度太長(zhǎng)會(huì)造成存儲(chǔ)空間的浪費(fèi)。
例如:
對(duì)“姓名”字段:中國(guó)人姓名一般不會(huì)太長(zhǎng),可以定義為char (10)。char(10)可以存儲(chǔ)5個(gè)中文字符。而在需要考慮少數(shù)民族或者其他名字很長(zhǎng)(例如外國(guó)人?)的情況下,則需要改成char(20)或者更長(zhǎng)。
二、選擇類(lèi)型不準(zhǔn)確可能會(huì)造成對(duì)后續(xù)操作的影響。
例如:
對(duì)“年齡”字段:理論上“年齡”可以定義成char和tinyint。當(dāng)不需要對(duì)年齡進(jìn)行計(jì)算時(shí),定義成char是沒(méi)有問(wèn)題的;但很多情況下,我們需要對(duì)年齡進(jìn)行計(jì)算、排序和比較等操作,選用tinyint會(huì)方便一些。而且正常地球人壽命不超過(guò)150,smallint和int的范圍太大,造成空間浪費(fèi)。
對(duì)“電話號(hào)碼”字段:建議用varchar類(lèi)型。電話號(hào)碼如果分固定電話和手機(jī)號(hào)碼的話,長(zhǎng)度不一。而varchar比char更靈活,長(zhǎng)度可變,而且存儲(chǔ)空間更小。
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信