詳解MySQL數(shù)據(jù)類型int(M)中M的含義
介紹
MySQL 數(shù)據(jù)類型中的 integer types 有點(diǎn)奇怪。你可能會(huì)見(jiàn)到諸如:int(3)、int(4)、int(8) 之類的 int 數(shù)據(jù)類型。剛接觸 MySQL 的時(shí)候,我還以為 int(3) 占用的存儲(chǔ)空間比 int(4) 要小, int(4) 占用的存儲(chǔ)空間比 int(8) 小。
后來(lái),參看 MySQL 手冊(cè),發(fā)現(xiàn)自己理解錯(cuò)了。
int(M): M indicates the maximum display width for integer types.
在 integer 數(shù)據(jù)類型中,M 表示最大顯示寬度。
原來(lái),在 int(M) 中,M 的值跟 int(M) 所占多少存儲(chǔ)空間并無(wú)任何關(guān)系。 int(3)、int(4)、int(8) 在磁盤(pán)上都是占用 4 btyes 的存儲(chǔ)空間。說(shuō)白了,除了顯示給用戶的方式有點(diǎn)不同外,int(M) 跟 int 數(shù)據(jù)類型是相同的。
另外,int(M) 只有跟 zerofill 結(jié)合起來(lái),才能使我們清楚的看到不同之處。
mysql> drop table if exists t; mysql> create table t(id int zerofill); mysql> insert into t(id) values(10); mysql> select * from t; +------------+ | id | +------------+ | 0000000010 | +------------+ mysql> alter table t change column id id int(3) zerofill; mysql> select * from t; +------+ | id | +------+ | 010 | +------+ mysql> mysql> alter table t change column id id int(4) zerofill; mysql> select * from t; +------+ | id | +------+ | 0010 | +------+ mysql> mysql> insert into t(id) values(1000000); mysql> select * from t; +---------+ | id | +---------+ | 0010 | | 1000000 | +---------+
從上面的測(cè)試可以看出,“(M)”指定了 int 型數(shù)值顯示的寬度,如果字段數(shù)據(jù)類型是 int(4),則:當(dāng)顯示數(shù)值 10 時(shí),在左邊要補(bǔ)上 “00”;當(dāng)顯示數(shù)值 100 是,在左邊要補(bǔ)上“0”;當(dāng)顯示數(shù)值 1000000 時(shí),已經(jīng)超過(guò)了指定寬度“(4)”,因此按原樣輸出。
在使用 MySQL 數(shù)據(jù)類型中的整數(shù)類型(tinyint、smallint、 mediumint、 int/integer、bigint)時(shí),非特殊需求下,在數(shù)據(jù)類型后加個(gè)“(M)”,我想不出有何意義。
下面補(bǔ)充一下數(shù)據(jù)類型
1、整型
MySQL數(shù)據(jù)類型 含義(有符號(hào)) tinyint(m) 1個(gè)字節(jié) 范圍(-128~127) smallint(m) 2個(gè)字節(jié) 范圍(-32768~32767) mediumint(m) 3個(gè)字節(jié) 范圍(-8388608~8388607) int(m) 4個(gè)字節(jié) 范圍(-2147483648~2147483647) bigint(m) 8個(gè)字節(jié) 范圍(+-9.22*10的18次方)
取值范圍如果加了unsigned,則最大值翻倍,如tinyint unsigned的取值范圍為(0~256)。
int(m)里的m是表示SELECT查詢結(jié)果集中的顯示寬度,并不影響實(shí)際的取值范圍,沒(méi)有影響到顯示的寬度,不知道這個(gè)m有什么用。
2、浮點(diǎn)型(float和double)
MySQL數(shù)據(jù)類型 含義 float(m,d) 單精度浮點(diǎn)型 8位精度(4字節(jié)) m總個(gè)數(shù),d小數(shù)位 double(m,d) 雙精度浮點(diǎn)型 16位精度(8字節(jié)) m總個(gè)數(shù),d小數(shù)位
設(shè)一個(gè)字段定義為float(5,3),如果插入一個(gè)數(shù)123.45678,實(shí)際數(shù)據(jù)庫(kù)里存的是123.457,但總個(gè)數(shù)還以實(shí)際為準(zhǔn),即6位。
3、定點(diǎn)數(shù)
浮點(diǎn)型在數(shù)據(jù)庫(kù)中存放的是近似值,而定點(diǎn)類型在數(shù)據(jù)庫(kù)中存放的是精確值。
decimal(m,d) 參數(shù)m<65 是總個(gè)數(shù),d<30且 d<m 是小數(shù)位。
4、字符串(char,varchar,_text)
MySQL數(shù)據(jù)類型 含義 char(n) 固定長(zhǎng)度,最多255個(gè)字符 varchar(n) 可變長(zhǎng)度,最多65535個(gè)字符 tinytext 可變長(zhǎng)度,最多255個(gè)字符 text 可變長(zhǎng)度,最多65535個(gè)字符 mediumtext 可變長(zhǎng)度,最多2的24次方-1個(gè)字符 longtext 可變長(zhǎng)度,最多2的32次方-1個(gè)字符
5、日期和時(shí)間數(shù)據(jù)類型
MySQL數(shù)據(jù)類型 含義 date 3字節(jié),日期,格式:2014-09-18 time 3字節(jié),時(shí)間,格式:08:42:30 datetime 8字節(jié),日期時(shí)間,格式:2014-09-18 08:42:30 timestamp 4字節(jié),自動(dòng)存儲(chǔ)記錄修改的時(shí)間 year 1字節(jié),年份
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
Python開(kāi)發(fā)之利用re模塊去除代碼塊注釋
Python的re模塊主要是正則表達(dá)式的操作函數(shù),下面這篇文章主要給大家介紹了關(guān)于Python開(kāi)發(fā)之利用re模塊去除代碼塊注釋的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11使用pandas把某一列的字符值轉(zhuǎn)換為數(shù)字的實(shí)例
今天小編就為大家分享一篇使用pandas把某一列的字符值轉(zhuǎn)換為數(shù)字的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01numpy.random.seed()的使用實(shí)例解析
這篇文章主要介紹了numpy.random.seed()的使用實(shí)例解析,分享了相關(guān)代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-02-02詳解Python 實(shí)現(xiàn)元胞自動(dòng)機(jī)中的生命游戲(Game of life)
本篇文章主要介紹了詳解Python 實(shí)現(xiàn)元胞自動(dòng)機(jī)中的生命游戲(Game of life),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01Python 創(chuàng)建守護(hù)進(jìn)程的示例
這篇文章主要介紹了Python 創(chuàng)建守護(hù)進(jìn)程的示例,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-09-09基于python不同開(kāi)根號(hào)的速度對(duì)比分析
這篇文章主要介紹了基于python不同開(kāi)根號(hào)的速度對(duì)比分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03python 簡(jiǎn)單備份文件腳本v1.0的實(shí)例
下面小編就為大家?guī)?lái)一篇python 簡(jiǎn)單備份文件腳本v1.0的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望對(duì)大家有所幫助2017-11-11python字典與json轉(zhuǎn)換的方法總結(jié)
在本篇文章里小編給大家整理的是一篇關(guān)于python字典與json轉(zhuǎn)換的方法總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2020-12-12Python基于OpenCV實(shí)現(xiàn)人臉檢測(cè)并保存
這篇文章主要介紹了Python基于OpenCV實(shí)現(xiàn)人臉檢測(cè)并保存,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07