欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL 數(shù)據(jù)類型之字符串、數(shù)字、日期詳解

 更新時間:2025年04月18日 11:15:26   作者:秋秋愛編碼  
MySQL 提供了多種數(shù)據(jù)類型,每種類型都有其適用場景,合理選擇數(shù)據(jù)類型可以提升存儲效率、優(yōu)化查詢性能,并避免精度損失,這篇文章主要介紹了MySQL數(shù)據(jù)類型詳解:字符串、數(shù)字、日期,需要的朋友可以參考下

MySQL 數(shù)據(jù)類型詳解:字符串、數(shù)字、日期

在 MySQL 中,選擇合適的數(shù)據(jù)類型對于數(shù)據(jù)庫的存儲效率查詢性能至關(guān)重要。MySQL 提供了**字符串(String)、數(shù)字(Numeric)和日期(Date & Time)**三大類數(shù)據(jù)類型,每種類型又有不同的子類型,以適應(yīng)不同的業(yè)務(wù)需求。

1. 字符串(String)數(shù)據(jù)類型

字符串類型用于存儲文本數(shù)據(jù),主要分為定長(CHAR)變長(VARCHAR),以及大文本(TEXT 和 BLOB)。

1.1 定長與變長字符串

數(shù)據(jù)類型存儲方式特點適用場景
CHAR(n)定長存儲(不足補空格)訪問速度快,占用空間固定適用于固定長度的數(shù)據(jù),如國家代碼、身份證號
VARCHAR(n)變長存儲(按需分配空間)節(jié)省存儲空間,但查詢時可能需要額外的存儲開銷適用于長度不固定的文本,如用戶昵稱、電子郵件

CHAR vs. VARCHAR

  • CHAR(10) 始終占用 10 個字節(jié)(不足補空格)。
  • VARCHAR(10) 只存儲實際字符,最多 10 個字節(jié),并額外占用 1-2 字節(jié)用于存儲長度信息。

一般來說:

  • 短小、長度固定的文本(如國家代碼、MD5 哈希)用 CHAR。
  • 長度不固定的文本(如姓名、地址)用 VARCHAR。

1.2 TEXT 和 BLOB

當(dāng)存儲較長的文本或二進制數(shù)據(jù)時,使用 TEXT 和 BLOB 類型:

數(shù)據(jù)類型最大存儲大小是否區(qū)分大小寫適用場景
TINYTEXT255 字節(jié)? 區(qū)分大小寫短文本,如推文內(nèi)容
TEXT65,535 字節(jié)(64KB)? 區(qū)分大小寫文章內(nèi)容、評論
MEDIUMTEXT16,777,215 字節(jié)(16MB)? 區(qū)分大小寫書籍、日志記錄
LONGTEXT4GB? 區(qū)分大小寫超長文本,如百科條目
TINYBLOB255 字節(jié)? 不區(qū)分大小寫小二進制數(shù)據(jù),如圖片縮略圖
BLOB64KB? 不區(qū)分大小寫圖片、音頻
MEDIUMBLOB16MB? 不區(qū)分大小寫大型媒體文件
LONGBLOB4GB? 不區(qū)分大小寫超大文件,如電影

TEXT vs. VARCHAR

  • TEXT 不支持 默認值,也無法使用 索引(僅支持前綴索引),但可以存儲大量文本。
  • VARCHAR 可以索引整個字段,適用于需要頻繁搜索的文本字段。

2. 數(shù)字(Numeric)數(shù)據(jù)類型

數(shù)字類型用于存儲整數(shù)或小數(shù),主要分為整數(shù)類型浮點/定點類型

2.1 整數(shù)類型

數(shù)據(jù)類型存儲大小取值范圍(無符號)適用場景
TINYINT1 字節(jié)0 ~ 255布爾值(0/1)、評分
SMALLINT2 字節(jié)0 ~ 65,535小范圍數(shù)值,如年齡
MEDIUMINT3 字節(jié)0 ~ 16,777,215適用于 ID、自增字段
INT(INTEGER)4 字節(jié)0 ~ 4,294,967,295適用于大部分場景,如用戶 ID
BIGINT8 字節(jié)0 ~ 18,446,744,073,709,551,615適用于超大數(shù)值,如銀行賬戶余額

無符號(UNSIGNED) vs. 有符號

  • TEXT 不支持 默認值,也無法使用 索引(僅支持前綴索引),但可以存儲大量文本。
  • VARCHAR 可以索引整個字段,適用于需要頻繁搜索的文本字段。

2. 數(shù)字(Numeric)數(shù)據(jù)類型

數(shù)字類型用于存儲整數(shù)或小數(shù),主要分為整數(shù)類型浮點/定點類型。

2.1 整數(shù)類型

數(shù)據(jù)類型存儲大小取值范圍(無符號)適用場景
TINYINT1 字節(jié)0 ~ 255布爾值(0/1)、評分
SMALLINT2 字節(jié)0 ~ 65,535小范圍數(shù)值,如年齡
MEDIUMINT3 字節(jié)0 ~ 16,777,215適用于 ID、自增字段
INT(INTEGER)4 字節(jié)0 ~ 4,294,967,295適用于大部分場景,如用戶 ID
BIGINT8 字節(jié)0 ~ 18,446,744,073,709,551,615適用于超大數(shù)值,如銀行賬戶余額

無符號(UNSIGNED) vs. 有符號

  • 默認情況下整數(shù)是有符號的(即支持負數(shù))。
  • UNSIGNED 關(guān)鍵字可以使整數(shù)僅存儲非負數(shù),從而擴大可用范圍。
CREATE TABLE users (
    id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY
);

2.2 浮點與定點類型

數(shù)據(jù)類型存儲大小適用場景
FLOAT(M, D)4 字節(jié)適用于非嚴格精度的計算,如游戲評分
DOUBLE(M, D)8 字節(jié)高精度計算,如科學(xué)計算
DECIMAL(M, D)(NUMERIC)可變財務(wù)計算,避免精度丟失

FLOAT vs. DECIMAL

FLOAT/DOUBLE 使用二進制存儲,可能導(dǎo)致精度誤差:

SELECT 0.1 + 0.2; -- 結(jié)果可能不是 0.3

DECIMAL 采用字符串存儲,不會丟失精度:

CREATE TABLE transactions (
    amount DECIMAL(10,2) NOT NULL
);

建議:

  • 財務(wù)類數(shù)據(jù)使用 DECIMAL,避免計算誤差。
  • 非關(guān)鍵計算(如統(tǒng)計數(shù)據(jù))可使用 FLOATDOUBLE。

3. 日期與時間(Date & Time)

MySQL 提供多個日期時間類型:

數(shù)據(jù)類型存儲大小適用場景
FLOAT(M, D)4 字節(jié)適用于非嚴格精度的計算,如游戲評分
DOUBLE(M, D)8 字節(jié)高精度計算,如科學(xué)計算
DECIMAL(M, D)(NUMERIC)可變財務(wù)計算,避免精度丟失

DATETIME vs. TIMESTAMP

  • TIMESTAMP 受時區(qū)影響,適合存儲事件發(fā)生時間。
  • DATETIME 不受時區(qū)影響,適合存儲固定時間。
CREATE TABLE events (
    event_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

4. 選擇數(shù)據(jù)類型的最佳實踐

  • 能用整數(shù)就不要用字符串(如性別可用 TINYINT)。
  • 存儲金額、財務(wù)數(shù)據(jù)時,使用 DECIMAL 而非 FLOAT。
  • 短文本(<255 字符)用 VARCHAR,長文本用 TEXT。
  • 索引字段盡量避免 TEXTBLOB,影響查詢性能。
  • 時間戳數(shù)據(jù)盡量使用 TIMESTAMP 代替 DATETIME,節(jié)省存儲空間。

總結(jié)

MySQL 提供了多種數(shù)據(jù)類型,每種類型都有其適用場景。合理選擇數(shù)據(jù)類型可以提升存儲效率、優(yōu)化查詢性能,并避免精度損失。希望這篇文章能幫助你在數(shù)據(jù)庫設(shè)計時做出更好的選擇!??

到此這篇關(guān)于MySQL 數(shù)據(jù)類型詳解:字符串、數(shù)字、日期的文章就介紹到這了,更多相關(guān)mysql數(shù)據(jù)類型內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論