SQL的常用數(shù)據(jù)類型列表詳解
數(shù)據(jù)類型 | 描述 |
---|---|
CHARACTER(n) | 字符/字符串。固定長度 n。 |
VARCHAR(n) 或 CHARACTER VARYING(n) |
字符/字符串??勺冮L度。最大長度 n。 |
BINARY(n) | 二進(jìn)制串。固定長度 n。 |
BOOLEAN | 存儲(chǔ) TRUE 或 FALSE 值 |
VARBINARY(n) 或 BINARY VARYING(n) |
二進(jìn)制串。可變長度。最大長度 n。 |
INTEGER(p) | 整數(shù)值(沒有小數(shù)點(diǎn))。精度 p。 |
SMALLINT | 整數(shù)值(沒有小數(shù)點(diǎn))。精度 5。 存儲(chǔ)數(shù)據(jù)的范圍是從-2的15次方(-32768)到2的15次方-1(32767),占用2個(gè)字節(jié)的儲(chǔ)存空間。 |
INTEGER | 整數(shù)值(沒有小數(shù)點(diǎn))。精度 10。 存儲(chǔ)數(shù)據(jù)的范圍是-2的31次方到2的31次方-1,占用4個(gè)字節(jié)的儲(chǔ)存空間。 |
BIGINT | 整數(shù)值(沒有小數(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ù)。該類型的 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ū)間的類型。 |
ARRAY | 元素的固定長度的有序集合 |
MULTISET | 元素的可變長度的無序集合 |
XML | 存儲(chǔ) XML 數(shù)據(jù) |
其中標(biāo)紅的是在建表時(shí)常用的數(shù)據(jù)類型。
數(shù)據(jù)類型的名稱在不同數(shù)據(jù)庫平臺(tái)中有一些區(qū)別,在SQL Server和MY SQL中(或者還有其他平臺(tái))數(shù)值型還有一個(gè)tinyint的類型(范圍從0到255)。
應(yīng)該注意根據(jù)實(shí)際情況選用不同的數(shù)據(jù)類型。
一、定義數(shù)據(jù)長度太長會(huì)造成存儲(chǔ)空間的浪費(fèi)。
例如:
對“姓名”字段:中國人姓名一般不會(huì)太長,可以定義為char (10)。char(10)可以存儲(chǔ)5個(gè)中文字符。而在需要考慮少數(shù)民族或者其他名字很長(例如外國人?)的情況下,則需要改成char(20)或者更長。
二、選擇類型不準(zhǔn)確可能會(huì)造成對后續(xù)操作的影響。
例如:
對“年齡”字段:理論上“年齡”可以定義成char和tinyint。當(dāng)不需要對年齡進(jìn)行計(jì)算時(shí),定義成char是沒有問題的;但很多情況下,我們需要對年齡進(jìn)行計(jì)算、排序和比較等操作,選用tinyint會(huì)方便一些。而且正常地球人壽命不超過150,smallint和int的范圍太大,造成空間浪費(fèi)。
對“電話號碼”字段:建議用varchar類型。電話號碼如果分固定電話和手機(jī)號碼的話,長度不一。而varchar比char更靈活,長度可變,而且存儲(chǔ)空間更小。
- 詳解SQL Server中的數(shù)據(jù)類型
- 詳解MySQL數(shù)據(jù)類型int(M)中M的含義
- mysql存儲(chǔ)引擎和數(shù)據(jù)類型(二)
- Java數(shù)據(jù)類型與MySql數(shù)據(jù)類型對照表
- SQL Server數(shù)據(jù)類型轉(zhuǎn)換方法
- SQL Server比較常見數(shù)據(jù)類型詳解
- SQLite教程(七):數(shù)據(jù)類型詳解
- SQL Server數(shù)據(jù)類型char、nchar、varchar、nvarchar的區(qū)別淺析
- sql使用cast進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換示例
- SQL2005中char nchar varchar nvarchar數(shù)據(jù)類型的區(qū)別和使用環(huán)境講解
相關(guān)文章
SQL語句實(shí)現(xiàn)查詢SQL Server服務(wù)器名稱和IP地址
這篇文章主要介紹了SQL語句實(shí)現(xiàn)查詢SQL Server服務(wù)器名稱和IP地址,本文分別給出查詢語句,需要的朋友可以參考下2015-07-07使用SQL語句創(chuàng)建觸發(fā)器的實(shí)例
觸發(fā)器 是一種特殊類型的存儲(chǔ)過程,它不同于我們前面介紹過的存儲(chǔ)過程。存儲(chǔ)過程可以通過語句直接調(diào)用,而 觸發(fā)器主要是通過事件進(jìn)行觸發(fā)而被執(zhí)行的,這篇文章主要介紹了使用SQL語句創(chuàng)建觸發(fā)器的實(shí)例,需要的朋友可以參考下2023-06-06SQL?Server修改數(shù)據(jù)的幾種語句詳解
在SQL中的基本操作就是增刪改查,查詢語句不會(huì)對數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行修改,下面這篇文章主要給大家介紹了關(guān)于SQL?Server修改數(shù)據(jù)的幾種語句,需要的朋友可以參考下2022-10-10