Mysql字段類(lèi)型

Mysql數(shù)據(jù)類(lèi)型

1. 數(shù)值類(lèi)型:

包括整數(shù)類(lèi)型TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT、浮點(diǎn)小數(shù)數(shù)據(jù)類(lèi)型FLOAT和DOUBLE,定點(diǎn)小數(shù)類(lèi)型DECIMAL。

類(lèi)型 存儲(chǔ) 范圍(有符號(hào)) 無(wú)符號(hào)
TINYINT 1字節(jié) -128~127 0~255()
SMALLINT 2字節(jié) 32768~32767 0~65535
MEDIUMINT 3字節(jié) -8388608~8388607 0~16777215
INT 4字節(jié) -2147483648~2147483647 0~4294967295
BIGINT 8字節(jié)
FLOAT 4字節(jié)
DOUBLE 8字節(jié)
DECIMAL(M,N) M+2字節(jié)

<b style="color:red">注意:</b>

CREATE TABLE test1(
   id INT(3),
   `name` VARCHAR(5),
   age INT(3)
);

id INT(3)括號(hào)內(nèi)的3不是限制存儲(chǔ)數(shù)據(jù)的大小,而是指示顯示寬度.顯示寬度和數(shù)據(jù)類(lèi)型的取值范圍是無(wú)關(guān)的

顯示寬度只用于顯示,并不能限制取值范圍和占用空間。例如:INT(3)會(huì)占用4字節(jié)的存儲(chǔ)空間,并且允許的最大值不會(huì)是999,而是INT整型所允許的最大值。顯示寬度只是指明MySQL最大可能顯示的數(shù)字個(gè)數(shù),數(shù)值的位數(shù)小于指定的寬度時(shí)會(huì)由空格填充

例如:向test1id = 999999的數(shù)據(jù)還是會(huì)成功.

INSERT INTO test1 VALUES(999999,'小明',12);

select * from test1 where id = 999999;

id       name    age
999999   小明  12

DECIMAL。浮點(diǎn)數(shù)類(lèi)型和定點(diǎn)數(shù)類(lèi)型都可以用(M,N)來(lái)表示。其中,M稱(chēng)為精度,表示總共的位數(shù);N稱(chēng)為標(biāo)度,表示小數(shù)的位數(shù).DECIMAL若不指定精度則默認(rèn)為(10,0)

不論是定點(diǎn)數(shù)還是浮點(diǎn)數(shù)類(lèi)型,如果用戶(hù)指定的精度超出精度范圍,則會(huì)四舍五入

CREATE TABLE test2(
  id INT(4),
  score DECIMAL(3,2)
);

INSERT INTO test2 VALUES(1,5.123),(2, 5.236),(3,5.1);

SELECT * FROM test2;
-- 結(jié)果
id  score  
1   5.12   
2   5.24   
3   5.10   

如果插入大于999.99的數(shù)就會(huì)報(bào)錯(cuò)了

insert into test2 values(4, 1000.4567);
-- 結(jié)果

查詢(xún):insert into test2 values(4, 1000.4567)

錯(cuò)誤代碼: 1264
Out of range value for column 'score' at row 1

2. 日期/時(shí)間類(lèi)型:

包括YEAR、TIME、DATE、DATETIME和TIMESTAMP

類(lèi)型 日期格式 范圍
YEAR YYYY 1901-2155 1字節(jié)
TIME HH:MM:SS 3字節(jié)
DATE YYYY-MM-DD 3字節(jié)
DATETIME YYYY-MM-DD HH:MM:SS 8字節(jié)
TIMESTAMP YYYY-MM-DD HH:MM:SS 4字節(jié)

注意: TIMESTAMP的范圍是1970年到2038年

TIMESTAMP與DATETIME除了存儲(chǔ)字節(jié)和支持的范圍不同外,還有一個(gè)最大的區(qū)別就是:DATETIME在存儲(chǔ)日期數(shù)據(jù)時(shí),按實(shí)際輸入的格式存儲(chǔ),即輸入什么就存儲(chǔ)什么,與時(shí)區(qū)無(wú)關(guān);而TIMESTAMP值的存儲(chǔ)是以UTC(世界標(biāo)準(zhǔn)時(shí)間)格式保存的,存儲(chǔ)時(shí)對(duì)當(dāng)前時(shí)區(qū)進(jìn)行轉(zhuǎn)換,檢索時(shí)再轉(zhuǎn)換回當(dāng)前時(shí)區(qū)。查詢(xún)時(shí),不同時(shí)區(qū)顯示的時(shí)間值是不同的。

DATE:

(1)以‘YYYY-MM-DD’或者‘YYYYMMDD’字符串格式表示的日期,取值范圍為‘1000-01-01’~‘9999-12-3’。例如,輸入‘2012-12-31’或者‘20121231’,插入數(shù)據(jù)庫(kù)的日期都為2012-12-31。

(2)以‘YY-MM-DD’或者‘YYMMDD’字符串格式表示的日期,在這里YY表示兩位的年值。包含兩位年值的日期會(huì)令人模糊,因?yàn)椴恢朗兰o(jì)。MySQL使用以下規(guī)則解釋兩位年值:‘00~69’范圍的年值轉(zhuǎn)換為‘2000~2069’;‘70~99’范圍的年值轉(zhuǎn)換為‘1970~1999’。例如,輸入‘12-12-31’,插入數(shù)據(jù)庫(kù)的日期為2012-12-31;輸入‘981231’,插入數(shù)據(jù)的日期為1998-12-31。

(3)以YY-MM-DD或者YYMMDD數(shù)字格式表示的日期,與前面相似,00~69范圍的年值轉(zhuǎn)換為2000~2069,70~99范圍的年值轉(zhuǎn)換為1970~1999。例如,輸入12-12-31插入數(shù)據(jù)庫(kù)的日期為2012-12-31;輸入981231,插入數(shù)據(jù)的日期為1998-12-31

3. 字符串類(lèi)型:

包括CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET等。字符串類(lèi)型又分為文本字符串和二進(jìn)制字符串

類(lèi)型 存儲(chǔ) 大小
CHAR(M) M字節(jié),1 <= M <=255
VARCHAR L+1字節(jié), L<= M ,
TINYTEXT 0-255 字節(jié)
TEXT 0-65535 字節(jié)
MEDIUMTEXT 0-16,777,215 字節(jié)
LONGTEXT 0-4,294,967,295 or 4GB 字節(jié)
ENUM 1或2字節(jié)
TINYBLOB 0-255 字節(jié)
BLOB 0-65535 字節(jié)
MEDIUMBLOB 0-16,777,215 字節(jié)
LONGBLOB 0-4,294,967,295 or 4GB 字節(jié)

varchar(M)說(shuō)明 括號(hào)內(nèi)的M和INT(4)類(lèi)型的限制不一樣,這里M對(duì)插入數(shù)據(jù)的長(zhǎng)度有限制,超長(zhǎng)就會(huì)報(bào)錯(cuò)

CREATE TABLE test3(
   id INT(4),
  `name` VARCHAR(5),
  `remark` varchar(1000)
);

insert into test3 values(1, '小紅','第一條數(shù)據(jù)');
-- 數(shù)據(jù)正常插入

id  name    remark           
1   小紅  第一條數(shù)據(jù)  

數(shù)據(jù)超長(zhǎng)情況

insert into test3 values(1, '這個(gè)名字真長(zhǎng)','第二條數(shù)據(jù)');
-- 顯示name字段超長(zhǎng)
<e>查詢(xún):insert into test3 values(1, '這個(gè)名字真長(zhǎng)','第二條數(shù)據(jù)')

錯(cuò)誤代碼: 1406
Data too long for column 'name' at row 1


INSERT INTO test3 VALUES(1, 'abcdef','第三條數(shù)據(jù)');
-- 顯示還是超長(zhǎng)
查詢(xún):INSERT INTO test3 VALUES(1, 'abcdef','第三條數(shù)據(jù)')

錯(cuò)誤代碼: 1406
Data too long for column 'name' at row 1

varchar字段長(zhǎng)度直接按字符計(jì)算不區(qū)分中英文字符

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 字段類(lèi)型數(shù)值MySQL 的數(shù)值數(shù)據(jù)類(lèi)型可以大致劃分為兩個(gè)類(lèi)別,一個(gè)是整數(shù),另一個(gè)是浮點(diǎn)數(shù)或小數(shù)。許多不同的子類(lèi)型對(duì)...
    小慕先森閱讀 1,269評(píng)論 0 1
  • 前言: 要了解一個(gè)數(shù)據(jù)庫(kù),我們必須了解其支持的數(shù)據(jù)類(lèi)型。MySQL 支持大量的字段類(lèi)型,其中常用的也有很多。前面文...
    MySQL技術(shù)閱讀 287評(píng)論 0 1
  • TINYINT 1 字節(jié)SMALLINT 2 個(gè)字節(jié)MEDIUMINT 3 個(gè)字節(jié)INT 4 個(gè)字節(jié)INTEGER...
    素年錦時(shí)2021閱讀 885評(píng)論 0 0
  • 1. bytes bytes = 8 bit 一個(gè)字節(jié)最多可以代表的數(shù)據(jù)長(zhǎng)度是2的8次方 11111111 在計(jì)算...
    CookieziSui閱讀 997評(píng)論 0 2
  • 最近需要對(duì)表加一個(gè)字段,同時(shí)覺(jué)得前期建立表的時(shí)候有點(diǎn)粗暴,沒(méi)有加很對(duì)限制,比如有些字符串長(zhǎng)度是有限制的,在創(chuàng)建表時(shí)...
    何甜甜在嗎閱讀 1,356評(píng)論 0 0

友情鏈接更多精彩內(nèi)容