MySQL INT類型全解析
前言:
整型是MySQL中最常用的字段類型之一,通常用于存儲整數(shù),其中int是整型中最常用的,對于int類型你是否真正了解呢?本文會帶你熟悉int類型相關(guān)知識,也會介紹其他整型字段的使用。
1.整型分類及存儲范圍
整數(shù)類型 | 字節(jié) | 有符號范圍 | 無符號范圍 |
TINYINT | 1 | -128 ~ 127 | 0 ~ 255 |
SMALLINT | 2 | -32768 ~ 32767 | 0 ~ 65535 |
MEDIUMINT | 3 | -8388608 ~ 8388607 | 0 ~ 16777215 |
INT/INTEGER | 4 | -2147483648 ~ 2147483647 | 0 ~ 4294967295 |
BIGINT | 8 | -9223372036854775808 ~ 9223372036854775807 | 0 ~ 18446744073709551615 |
表格一共有四列分別表示:字段類型, 占用字節(jié)數(shù), 有符號范圍, 無符號范圍。
我們拿int類型為例:
int類型, 占用字節(jié)數(shù)為4byte, 學(xué)過計(jì)算機(jī)原理的同學(xué)應(yīng)該知道, 字節(jié)(byte)并非是計(jì)算機(jī)存儲的最小單位, 還有比字節(jié)(byte)更小的單位, 也就是位(bit),一個(gè)位就代表一個(gè)0或1; 8個(gè)位組成一個(gè)字節(jié); 一般字節(jié)用大寫B(tài)來表示byte, 位用小寫b來表示bit.
計(jì)算機(jī)存儲單位的換算: 1B=8b 1KB=1024B 1MB=1024KB
那么根據(jù)int類型允許存儲的字節(jié)數(shù)是4個(gè)字節(jié), 我們就能換算出int UNSIGNED(無符號)類型的能存儲的最小值為0, 最大值為4294967295(即4B=32b, 最大值即為32個(gè)1組成,即4294967295換算成二進(jìn)制則是32個(gè)1)。
2.存儲范圍測試
mysql> CREATE TABLE test_int ( -> col1 TINYINT, -> col2 SMALLINT, -> col3 MEDIUMINT, -> col4 INT, -> col5 BIGINT -> ) ENGINE = INNODB DEFAULT CHARSET = utf8;Query OK, 0 rows affected (0.01 sec) mysql> show create table test_int\G*************************** 1. row *************************** Table: test_intCreate Table: CREATE TABLE `test_int` ( `col1` tinyint(4) DEFAULT NULL, `col2` smallint(6) DEFAULT NULL, `col3` mediumint(9) DEFAULT NULL, `col4` int(11) DEFAULT NULL, `col5` bigint(20) DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf81 row in set (0.00 sec) mysql> insert into test_int values (1234,123456,12345678,12345678901,12345678901234567890);Query OK, 1 row affected, 5 warnings (0.00 sec) mysql> insert into test_int values (-1234,-123456,-12345678,-12345678901,-12345678901234567890);Query OK, 1 row affected, 5 warnings (0.01 sec) mysql> show warnings;+---------+------+-----------------------------------------------+| Level | Code | Message |+---------+------+-----------------------------------------------+| Warning | 1264 | Out of range value for column 'col1' at row 1 || Warning | 1264 | Out of range value for column 'col2' at row 1 || Warning | 1264 | Out of range value for column 'col3' at row 1 || Warning | 1264 | Out of range value for column 'col4' at row 1 || Warning | 1264 | Out of range value for column 'col5' at row 1 |+---------+------+-----------------------------------------------+5 rows in set (0.01 sec) mysql> select * from test_int;+------+--------+----------+-------------+----------------------+| col1 | col2 | col3 | col4 | col5 |+------+--------+----------+-------------+----------------------+| 127 | 32767 | 8388607 | 2147483647 | 9223372036854775807 || -128 | -32768 | -8388608 | -2147483648 | -9223372036854775808 |+------+--------+----------+-------------+----------------------+
從上述測試中我們可以看出:有符號時(shí),各種整型類型最大的存儲范圍,當(dāng)存儲數(shù)字大小不在存儲范圍時(shí),MySQL會產(chǎn)生告警,但數(shù)字可以插入,默認(rèn)截取為可存儲的最大值或最小值。
3.int(M)中M的含義與zerofill的使用
我們經(jīng)常聽到這句話:int(M)中的M代表最大顯示寬度,"最大顯示寬度"我們第一反應(yīng)是該字段的值最大能允許存放的值的寬度,以為我們建了int(1),就不能存放數(shù)據(jù)10了, 其實(shí)不是這個(gè)意思。
整數(shù)列的顯示寬度與mysql需要用多少個(gè)字符來顯示該列數(shù)值,與該整數(shù)需要的存儲空間的大小都沒有關(guān)系,比如,不管設(shè)定了顯示寬度是多少個(gè)字符,int都是占用4個(gè)字節(jié),bigint都要占用8個(gè)字節(jié)。即int(5)和int(10)可存儲的范圍一樣。
整型字段有個(gè)ZEROFILL屬性(0填充),在數(shù)字長度不夠的數(shù)據(jù)前面填充0,以達(dá)到設(shè)定的長度。加上ZEROFILL后M才表現(xiàn)出不同,當(dāng)使用ZEROFILL時(shí),默認(rèn)會自動(dòng)加unsigned(無符號)屬性。比如 INT(3) ZEROFILL,你插入到數(shù)據(jù)庫里的是10,則實(shí)際插入為010,也就是在前面補(bǔ)充加了一個(gè)0,下面我們來測試下:
mysql> CREATE TABLE test_int_zerofill ( -> col1 INT(5) ZEROFILL, -> col2 INT ZEROFILL, -> col3 INT(5) -> ) ENGINE=InnoDB DEFAULT CHARSET=utf8;Query OK, 0 rows affected (0.01 sec) mysql> show create table test_int_zerofill\G*************************** 1. row *************************** Table: test_int_zerofillCreate Table: CREATE TABLE `test_int_zerofill` ( `col1` int(5) unsigned zerofill DEFAULT NULL, `col2` int(10) unsigned zerofill DEFAULT NULL, `col3` int(5) DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf81 row in set (0.00 sec) mysql> insert into test_int_zerofill values (12,12,12);Query OK, 1 row affected (0.00 sec) mysql> select * from test_int_zerofill;+-------+------------+------+| col1 | col2 | col3 |+-------+------------+------+| 00012 | 0000000012 | 12 |+-------+------------+------+1 row in set (0.00 sec)
那么有同學(xué)可能會問zerofill有什么應(yīng)用場景呢,比較常用的應(yīng)該是月份或日期前補(bǔ)0,這樣顯示的會規(guī)范些
CREATE TABLE `t_zerofill` ( `year` year(4) DEFAULT NULL, `month` int(2) unsigned zerofill DEFAULT NULL, `day` int(2) unsigned zerofill DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; mysql> insert into t_zerofill values (2019,6,5);Query OK, 1 row affected (0.01 sec) mysql> insert into t_zerofill values (2019,6,18);Query OK, 1 row affected (0.00 sec) mysql> insert into t_zerofill values (2019,10,1);Query OK, 1 row affected (0.00 sec) mysql> insert into t_zerofill values (2019,11,11);Query OK, 1 row affected (0.01 sec) mysql> select * from t_zerofill;+------+-------+------+| year | month | day |+------+-------+------+| 2019 | 06 | 05 || 2019 | 06 | 18 || 2019 | 10 | 01 || 2019 | 11 | 11 |+------+-------+------+4 rows in set (0.00 sec)
4.類型選取
經(jīng)過上面的介紹,關(guān)于不同整型字段的選取變得容易很多。本著最小化存儲的原則,當(dāng)然是能選TINYINT不選SMALLINT,能選MEDIUMINT不選INT了,不過一切都要滿足業(yè)務(wù)的前提下盡量選取占用字節(jié)更少的類型。對于確定只存儲正整數(shù)的字段,可以加上unsigned屬性,這樣會使存儲范圍更大,比如當(dāng)字段有AUTO_INCREMENT屬性時(shí),我們可以為int類型加上unsigned屬性。
以上就是MySQL INT類型全解析的詳細(xì)內(nèi)容,更多關(guān)于MySQL INT類型的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
關(guān)于Mysql中json數(shù)據(jù)類型的查詢操作指南
mysql在5.7版本之后就開始支持json數(shù)據(jù)類型,并且mysql8.0版本對json的處理已經(jīng)做的非常完善了,json數(shù)據(jù)類型的優(yōu)點(diǎn)缺點(diǎn)可自己查詢,本文主要介紹一些關(guān)于json數(shù)據(jù)類型的查詢操作2023-07-07MySQL數(shù)據(jù)庫實(shí)驗(yàn)之?觸發(fā)器和存儲過程
這篇文章主要介紹了MySQL數(shù)據(jù)庫實(shí)驗(yàn)之?觸發(fā)器和存儲過程,通過掌握某主流DBMS支持的SQL編程語言和編程規(guī)范,規(guī)范設(shè)計(jì)存儲過程展開詳細(xì)介紹,感興趣的朋友可以參考一下2022-06-06MySQLBackup備份數(shù)據(jù)庫的操作過程
這篇文章主要介紹了MySQLBackup備份數(shù)據(jù)庫的操作過程,包括安裝部署和配置備份管理員的相關(guān)知識,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-03-03計(jì)算機(jī)二級考試MySQL??键c(diǎn) 8種MySQL數(shù)據(jù)庫設(shè)計(jì)優(yōu)化方法
這篇文章主要為大家詳細(xì)介紹了計(jì)算機(jī)二級考試MySQL??键c(diǎn),詳細(xì)介紹8種MySQL數(shù)據(jù)庫設(shè)計(jì)優(yōu)化方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08MySQL性能優(yōu)化的最佳20+條經(jīng)驗(yàn)
這篇文章主要為大家詳細(xì)介紹了MySQL性能優(yōu)化的最佳20+條經(jīng)驗(yàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09MySQL忘記root密碼以及遠(yuǎn)程無法連接的解決方法
這篇文章主要介紹了MySQL忘記root密碼以及遠(yuǎn)程無法連接問題的解決方法,文中有詳細(xì)的代碼示例來解決這些辦法,需要的朋友可以參考下2023-06-06mysql.help_topic生成序列的方法實(shí)現(xiàn)
本文探討了如何使用MySQL的help_topic表生成序列,并介紹了相應(yīng)的SQL查詢語句和實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10