Mysql中的數(shù)據(jù)類型用法及解讀
1.1數(shù)據(jù)類型分類
MySQL 數(shù)據(jù)類型可以分為三大類:
- 數(shù)值類型:包括整數(shù)類型、浮點類型、定點類型等。
- 字符串類型:包括
CHAR
、VARCHAR
、TEXT
等。 - 日期和時間類型:包括
DATE
、DATETIME
、TIMESTAMP
等。
1.2 數(shù)值類型
數(shù)值類型在 MySQL 中主要有整型和小數(shù)型兩種類型。
1.2.1 tinyint 類型
tinyint
類型是一個小的整數(shù)類型,通常用于存儲小范圍的整數(shù)。
范圍:
- 有符號:-128 到 127
- 無符號:0 到 255
- 如果插入超出該范圍的值,MySQL 會報錯。
示例:
CREATE TABLE tt1 (num tinyint); INSERT INTO tt1 VALUES(1); -- 成功插入 INSERT INTO tt1 VALUES(128); -- 報錯,超出范圍
有符號正數(shù):
有符號負(fù)數(shù):
無符號數(shù):
1.2.2 bit 類型
bit
類型用于存儲位字段,可以存儲二進(jìn)制數(shù)據(jù)。
示例:
CREATE TABLE tt4 (id INT, a BIT(8)); INSERT INTO tt4 VALUES(10, 10); -- 存入10,顯示可能是位二進(jìn)制值
(bit[(M)] : 位字段類型。M表示每個值的位數(shù),范圍從1到64。如果M被忽略,默認(rèn)為1。)
- 你可以定義存儲的位數(shù),例如
bit(8)
表示存儲 8 位的二進(jìn)制數(shù)。 - 默認(rèn)情況下,
bit
類型在存儲時會顯示為 ASCII 字符。
注:bit字段在顯示時,是按照ASCII碼對應(yīng)的值顯示
1.2.3 小數(shù)類型
1.2.3.1 float 類型
float
類型用于存儲浮動的小數(shù)值,支持四舍五入。
- 你可以通過
float(M, D)
來定義精度和小數(shù)位數(shù),其中M
為總位數(shù),D
為小數(shù)位數(shù)。
示例:
CREATE TABLE tt6 (id INT, salary FLOAT(4, 2)); INSERT INTO tt6 VALUES(100, -99.99); -- 成功插入 INSERT INTO tt6 VALUES(101, -99.991); -- 會進(jìn)行四舍五入,存儲為 -99.99
案例:
小數(shù):float(4,2)表示的范圍是-99.99 ~ 99.99,MySQL在保存值時會進(jìn)行四舍五入。
如果是無符號數(shù)的float,其中的負(fù)數(shù)部分會被舍去。例如:
無符號小數(shù):float(4,2)表示的范圍是0 ~ 99.99,MySQL在保存值時會進(jìn)行四舍五入。
1.2.3.2 decimal 類型
decimal
類型是定點數(shù),精度更高,適用于需要精確存儲小數(shù)的情況。
decimal(M, D)
表示最多可以存儲M
位數(shù),其中D
位是小數(shù)部分。
示例:
CREATE TABLE tt7 (id INT, salary DECIMAL(5, 2)); INSERT INTO tt7 VALUES(100, 99.99); -- 成功插入
注: decimal類型和float類型很像,他們都支持四舍五入,他們的無符號類型都是舍去負(fù)數(shù),但是decimal類型的精度比float類型更高。
例如:
1.3 字符串類型
1.3.1 char 類型
char
是固定長度的字符串類型,適用于存儲長度固定的字符串?dāng)?shù)據(jù)。
- 長度
L
最大為 255 字符。
示例:
CREATE TABLE tt9 (id INT, name CHAR(2)); INSERT INTO tt9 VALUES(100, 'ab'); -- 成功插入 INSERT INTO tt9 VALUES(101, '中國'); -- 成功插入
1.3.2 varchar 類型
varchar
是可變長度的字符串類型,適用于存儲長度不固定的字符串?dāng)?shù)據(jù)。
- 最大長度是 65535 字節(jié),實際存儲的長度取決于字符集。
示例:
CREATE TABLE tt10 (id INT, name VARCHAR(6)); INSERT INTO tt10 VALUES(100, 'hello'); -- 成功插入 INSERT INTO tt10 VALUES(100, '我愛你,中國'); -- 成功插入
請思考為什么會出現(xiàn)這種情況?
原因是:CHAR
和 VARCHAR
類型在 MySQL 中存儲的是字符而非字節(jié)。在默認(rèn)的 utf8
字符集下,每個字符通常占用 3 個字節(jié)。
由于 VARCHAR
是可變長度的字符串類型,它不僅存儲字符本身,還需要額外的空間來記錄實際數(shù)據(jù)的長度。因此,在 utf8
編碼下,VARCHAR
字段的最大字符數(shù)是 21844。
這個限制是因為 VARCHAR
的最大字節(jié)數(shù)為 65535 字節(jié),而每個字符占用 3 個字節(jié),再加上存儲長度的開銷(最多 3 個字節(jié)),因此實際能存儲的最大字符數(shù)為 65535 / 3 = 21845
,減去存儲長度所需的空間后,最終可以存儲最多 21844 個字符。
1.3.3charVSvarchar
如何選擇定長或變長字符串?
定長(CHAR
):
如果數(shù)據(jù)的長度確定且不會變化,使用定長(CHAR
)類型更為合適。例如:身份證、手機(jī)號、MD5 值等。
變長(VARCHAR
):
如果數(shù)據(jù)的長度有變化,可以使用變長(VARCHAR
)類型。例如:名字、地址等數(shù)據(jù)。
優(yōu)缺點對比:
定長(CHAR
):
優(yōu)點:
- 存儲固定長度的數(shù)據(jù)時效率高。
- 因為空間已經(jīng)預(yù)分配,查詢時訪問速度較快。
缺點:
- 存儲短于定義長度的數(shù)據(jù)時會浪費空間。
- 例如,
CHAR(10)
存儲 3 個字符的數(shù)據(jù)時,會浪費 7 個字符的空間。
變長(VARCHAR
):
優(yōu)點:
- 根據(jù)實際字符長度分配空間,節(jié)省存儲。
缺點:
- 需要動態(tài)計算長度,相比
CHAR
稍慢。 - 在頻繁查詢或更新時,效率可能較低
1.4 日期和時間類型
常用的日期和時間類型:
- DATE:存儲日期,格式為
'yyyy-mm-dd'
。 - DATETIME:存儲日期和時間,格式為
'yyyy-mm-dd HH:ii:ss'
。 - TIMESTAMP:存儲時間戳,從1970年1月1日開始計算。
1.5 enum 和 set 類型
1.5.1 enum 類型
enum
類型用于存儲“單選”項。每個選項都有一個數(shù)字編號,對應(yīng)存儲在數(shù)據(jù)庫中的實際值。
示例:
CREATE TABLE votes (username VARCHAR(30), gender ENUM('男', '女')); INSERT INTO votes VALUES('張三', '男');
enum里面的值默認(rèn)下表從0開始,0表示空NULL
1.5.2 set 類型
set
類型用于存儲“多選”項,可以選擇多個值,值的組合會以數(shù)字標(biāo)識。
示例:
CREATE TABLE votes (username VARCHAR(30), hobby SET('登山', '游泳', '籃球', '武術(shù)')); INSERT INTO votes VALUES('雷鋒', '登山,游泳');
愛好: | 爬山 | 登月 | 打球 | 游泳 | 睡覺 |
6 | 0 | 1 | 1 | 0 | 0 |
5 | 1 | 0 | 1 | 0 | 0 |
原因: SET
類型中的值是按二進(jìn)制位存儲的,每個選項對應(yīng)一個二進(jìn)制位。每個選項的值會用一個數(shù)字表示,數(shù)字的每一位代表一個選項的狀態(tài)(是否選中)。這樣可以節(jié)省存儲空間。
1.6 find_in_set函數(shù)
find_in_set(sub, str_list)
函數(shù)用于查找一個字符串是否在由逗號分隔的字符串列表中。
- 如果
sub
在str_list
中,返回其位置(下標(biāo))。 - 如果
sub
不在str_list
中,返回 0。
示例:
find_in_set('a', 'a,b,c')
返回 1,表示'a'
在'a,b,c'
中的第一個位置。find_in_set('d', 'a,b,c')
返回 0,表示'd'
不在'a,b,c'
中。
同時它可以讓查找更方便
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
mysql下普通用戶備份數(shù)據(jù)庫時無lock tables權(quán)限的解決方法
mysql使用普通用戶備份出現(xiàn)無lock tables權(quán)限的解決方法,需要的朋友可以參考下。2011-10-10MySQL9.0的兩種部署模式及各個版本發(fā)布的新功能
本文主要介紹了MySQL9.0的兩種部署模式及各個版本發(fā)布的新功能,文中通過圖文示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-08-08