《Mysql入門(mén)MySQL整型數(shù)據(jù)溢出的解決方法》要點(diǎn):
本文介紹了Mysql入門(mén)MySQL整型數(shù)據(jù)溢出的解決方法,希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
今天接到一個(gè)朋友電話說(shuō)是覺(jué)的數(shù)據(jù)庫(kù)被別人更改了,出現(xiàn)數(shù)據(jù)不對(duì)的問(wèn)題 .經(jīng)過(guò)很久的排查是數(shù)據(jù)類(lèi)型溢出了(發(fā)生問(wèn)題的版本是MySQL 5.1).后來(lái)通過(guò)給朋友那邊把MySQL 5.1升級(jí)到MySQL 5.5去解決這個(gè)問(wèn)題. 這也讓我有興趣去了解一下MySQL不同版本數(shù)據(jù)類(lèi)型溢出的處理機(jī)制.MYSQL應(yīng)用
先看一下MySQL支持的整型數(shù)及大小,存儲(chǔ)空間:MYSQL應(yīng)用
pe | Storage | Minimum Value | Maximum Value | 存儲(chǔ)大小 |
---|---|---|---|---|
? | (Bytes) | (Signed/Unsigned) | (Signed/Unsigned) | byte |
TINYINT | 1 | -128 | 127 | 1 byte |
? | ? | 0 | 255 | ? |
SMALLINT | 2 | -32768 | 32767 | 2 bytes |
? | ? | 0 | 65535 | ? |
MEDIUMINT | 3 | -8388608 | 8388607 | 3 bytes |
? | ? | 0 | 16777215 | ? |
INT | 4 | -2147483648 | 2147483647 | 4 bytes |
? | ? | 0 | 4294967295 | ? |
BIGINT | 8 | -9223372036854775808 | 9223372036854775807 | 8 bytes |
? | ? | 0 | 18446744073709551615 | ? |
另外請(qǐng)記著mysql的數(shù)據(jù)處理會(huì)轉(zhuǎn)成bigint處理,所以這里就用bigint幾個(gè)測(cè)試:MYSQL應(yīng)用
SELECT 9223372036854775807 + 1;
MYSQL應(yīng)用
MySQL 5.1 下:
MYSQL應(yīng)用
mysql> SELECT 9223372036854775807 + 1;
+-------------------------+
| 9223372036854775807 + 1 |
+-------------------------+
|??? -9223372036854775808 |
+-------------------------+
1 row in set (0.01 sec)
MYSQL應(yīng)用
MySQL 5.5, 5.6, 5.7下:
MYSQL應(yīng)用
所在處理這類(lèi)數(shù)據(jù)是一定要小心溢出(如早期有做弊沖Q幣就是利用這個(gè)方法處理)MYSQL應(yīng)用
這個(gè)問(wèn)題有可能會(huì)出現(xiàn)積分消息,積分相加, 或是一些錢(qián)相關(guān)的業(yè)務(wù)中出現(xiàn), 主庫(kù)5.1 ,從庫(kù)MySQL 5.5情況也會(huì)出現(xiàn)不同步的問(wèn)題.
建議:這類(lèi)業(yè)務(wù)系統(tǒng)盡可能的升級(jí)到MySQL 5.5后版本 MYSQL應(yīng)用
更多詳情參考: http://dev.mysql.com/doc/refman/5.7/en/out-of-range-and-overflow.htmlMYSQL應(yīng)用
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/3342.html