在MySQL中,整型數(shù)據(jù)類(lèi)型分為四種:TINYINT、SMALLINT、MEDIUMINT和INT。它們的存儲(chǔ)范圍分別為-128~127、-32768~32767、-8388608~8388607和-2147483648~2147483647。如果需要存儲(chǔ)超過(guò)INT的范圍的整數(shù),我們可以考慮以下幾種解決方案。
1.使用BIGINT數(shù)據(jù)類(lèi)型
MySQL的BIGINT數(shù)據(jù)類(lèi)型可以存儲(chǔ)范圍在-9223372036854775808~9223372036854775807之間的整數(shù)。如果需要存儲(chǔ)超過(guò)INT范圍的整數(shù),可以考慮使用BIGINT。
CREATE TABLE `test` (t(20) NOT NULL AUTO_INCREMENT,umbert(20) NOT NULL,
2.使用DECIMAL數(shù)據(jù)類(lèi)型
DECIMAL數(shù)據(jù)類(lèi)型可以存儲(chǔ)固定精度的小數(shù),可以存儲(chǔ)任意大小的整數(shù)。DECIMAL(M,D)中M表示總共的位數(shù),D表示小數(shù)點(diǎn)后的位數(shù)。
CREATE TABLE `test` (t(11) NOT NULL AUTO_INCREMENT,umberal(30,0) NOT NULL,
3.使用字符串類(lèi)型
如果不需要進(jìn)行數(shù)值計(jì)算,可以考慮使用字符串類(lèi)型存儲(chǔ)超過(guò)10位的整數(shù)。VARCHAR和TEXT類(lèi)型都可以存儲(chǔ)字符串類(lèi)型的數(shù)據(jù)。
CREATE TABLE `test` (t(11) NOT NULL AUTO_INCREMENT,umber` varchar(20) NOT NULL,
以上就是幾種解決MySQL中超過(guò)10位的整型問(wèn)題的方法。根據(jù)實(shí)際需求選擇合適的解決方案,可以避免數(shù)據(jù)的丟失和錯(cuò)誤。