MySQL整型數(shù)據(jù)溢出的解決方法
今天接到一個朋友電話說是覺的數(shù)據(jù)庫被別人更改了,出現(xiàn)數(shù)據(jù)不對的問題 。經(jīng)過很久的排查是數(shù)據(jù)類型溢出了(發(fā)生問題的版本是MySQL 5.1)。后來通過給朋友那邊把MySQL 5.1升級到MySQL 5.5去解決這個問題?!∵@也讓我有興趣去了解一下MySQL不同版本數(shù)據(jù)類型溢出的處理機制。
先看一下MySQL支持的整型數(shù)及大小,存儲空間:
| pe | Storage | Minimum Value | Maximum Value | 存儲大小 |
|---|---|---|---|---|
| (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 |
另外請記著mysql的數(shù)據(jù)處理會轉(zhuǎn)成bigint處理,所以這里就用bigint幾個測試:
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幣就是利用這個方法處理)
這個問題有可能會出現(xiàn)積分消息,積分相加, 或是一些錢相關(guān)的業(yè)務(wù)中出現(xiàn), 主庫5.1 ,從庫MySQL 5.5情況也會出現(xiàn)不同步的問題。
建議:這類業(yè)務(wù)系統(tǒng)盡可能的升級到MySQL 5.5后版本
更多詳情參考: http://dev.mysql.com/doc/refman/5.7/en/out-of-range-and-overflow.html
相關(guān)文章
mysql日志系統(tǒng)redo log和bin log介紹
這篇文章主要介紹了mysql日志系統(tǒng)redo log和bin log介紹,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08
MySQL數(shù)據(jù)定義語言DDL的基礎(chǔ)語句
這篇文章主要介紹了MySQL數(shù)據(jù)定義語言DDL的基礎(chǔ)語句,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08
給mysql數(shù)據(jù)庫的字段設(shè)默認值方式
這篇文章主要介紹了給mysql數(shù)據(jù)庫的字段設(shè)默認值方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
ubuntu下mysql?8.0.28 安裝配置方法圖文教程
這篇文章主要為大家詳細介紹了ubuntu下mysql?8.0.28安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04
Mysql中replace與replace into的用法講解
今天小編就為大家分享一篇關(guān)于Mysql中replace與replace into的用法講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03

