MySQL整型數(shù)據(jù)溢出的解決方法
今天接到一個(gè)朋友電話說(shuō)是覺(jué)的數(shù)據(jù)庫(kù)被別人更改了,出現(xiàn)數(shù)據(jù)不對(duì)的問(wèn)題 。經(jīng)過(guò)很久的排查是數(shù)據(jù)類型溢出了(發(fā)生問(wèn)題的版本是MySQL 5.1)。后來(lái)通過(guò)給朋友那邊把MySQL 5.1升級(jí)到MySQL 5.5去解決這個(gè)問(wèn)題。 這也讓我有興趣去了解一下MySQL不同版本數(shù)據(jù)類型溢出的處理機(jī)制。
先看一下MySQL支持的整型數(shù)及大小,存儲(chǔ)空間:
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è)試:
SELECT CAST(0 AS UNSIGNED) - 1;
SELECT 9223372036854775807 + 1;
MySQL 5.1 下:
mysql> SELECT CAST(0 AS UNSIGNED) - 1;
+-------------------------+
| CAST(0 AS UNSIGNED) - 1 |
+-------------------------+
| 18446744073709551615 |
+-------------------------+
1 row in set (0.01 sec)
mysql> SELECT 9223372036854775807 + 1;
+-------------------------+
| 9223372036854775807 + 1 |
+-------------------------+
| -9223372036854775808 |
+-------------------------+
1 row in set (0.01 sec)
MySQL 5.5, 5.6, 5.7下:
mysql> SELECT CAST(0 AS UNSIGNED) - 1;
ERROR 1690 (22003): BIGINT UNSIGNED value is out of range in '(cast(0 as unsigned) - 1)'
mysql>
mysql>
mysql>
mysql> SELECT 9223372036854775807 + 1;
ERROR 1690 (22003): BIGINT value is out of range in '(9223372036854775807 + 1)'
所在處理這類數(shù)據(jù)是一定要小心溢出(如早期有做弊沖Q幣就是利用這個(gè)方法處理)
這個(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)題。
建議:這類業(yè)務(wù)系統(tǒng)盡可能的升級(jí)到MySQL 5.5后版本
更多詳情參考: http://dev.mysql.com/doc/refman/5.7/en/out-of-range-and-overflow.html
相關(guān)文章
mysql常見(jiàn)的錯(cuò)誤提示問(wèn)題處理小結(jié)
本文總結(jié)了在使用mysql過(guò)程中經(jīng)常遇到的3種錯(cuò)誤提示(error1067,error1061,error1045)的問(wèn)題的處理方法,都是本人在實(shí)際應(yīng)用中處理檢驗(yàn)過(guò)的,希望對(duì)大家有所幫助2014-08-08mysql遞歸函數(shù)with?recursive的用法舉例
在實(shí)際開(kāi)發(fā)的過(guò)程中,我們會(huì)遇到一些數(shù)據(jù)是層級(jí)關(guān)系的、要展示數(shù)據(jù)子父級(jí)關(guān)系的時(shí)候,下面這篇文章主要給大家介紹了關(guān)于mysql遞歸函數(shù)with?recursive的用法舉例,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08mysql 控制臺(tái)程序的提示符 prompt 字符串設(shè)置
mysql 控制臺(tái)程序的提示符 prompt 字符串設(shè)置,學(xué)習(xí)mysql的朋友可以參考下。2011-08-08CMD命令操作MySql數(shù)據(jù)庫(kù)的方法詳解
今天小編就為大家分享一篇關(guān)于CMD命令操作MySql數(shù)據(jù)庫(kù)的方法詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02MySQL中表子查詢與關(guān)聯(lián)子查詢的基礎(chǔ)學(xué)習(xí)教程
這篇文章主要介紹了MySQL中表子查詢與關(guān)聯(lián)子查詢的基礎(chǔ)學(xué)習(xí)教程,同時(shí)文中也提到了關(guān)于關(guān)聯(lián)子查詢的查詢效率問(wèn)題,需要的朋友可以參考下2015-12-12MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解
這篇文章主要介紹了MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11mysql實(shí)現(xiàn)sequence功能的代碼
今天小編就為大家分享一篇關(guān)于mysql實(shí)現(xiàn)sequence功能的代碼,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03MySQL存儲(chǔ)過(guò)程中游標(biāo)循環(huán)的跳出和繼續(xù)操作示例
這篇文章主要介紹了MySQL存儲(chǔ)過(guò)程中游標(biāo)循環(huán)的跳出和繼續(xù)操作示例,解決了在MySQL存儲(chǔ)過(guò)程中循環(huán)時(shí)執(zhí)行游標(biāo)的一個(gè)conitnue的操作解決方法,需要的朋友可以參考下2014-07-07