国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL整型數據溢出的解決方法

2020-01-18 23:10:41
字體:
來源:轉載
供稿:網友

今天接到一個朋友電話說是覺的數據庫被別人更改了,出現數據不對的問題 。經過很久的排查是數據類型溢出了(發生問題的版本是MySQL 5.1)。后來通過給朋友那邊把MySQL 5.1升級到MySQL 5.5去解決這個問題。 這也讓我有興趣去了解一下MySQL不同版本數據類型溢出的處理機制。

先看一下MySQL支持的整型數及大小,存儲空間:

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的數據處理會轉成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)'

所在處理這類數據是一定要小心溢出(如早期有做弊沖Q幣就是利用這個方法處理)

這個問題有可能會出現積分消息,積分相加, 或是一些錢相關的業務中出現, 主庫5.1 ,從庫MySQL 5.5情況也會出現不同步的問題。
建議:這類業務系統盡可能的升級到MySQL 5.5后版本 

更多詳情參考: http://dev.mysql.com/doc/refman/5.7/en/out-of-range-and-overflow.html

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 中山市| 卢龙县| 古浪县| 莱州市| 北流市| 沧源| 三原县| 盐边县| 宣汉县| 绥化市| 剑河县| 馆陶县| 泾源县| 什邡市| 顺昌县| 佳木斯市| 新田县| 沅江市| 建宁县| 大关县| 吉林省| 噶尔县| 呼伦贝尔市| 灵宝市| 元朗区| 天祝| 山东| 密云县| 普兰店市| 苍溪县| 乐陵市| 珲春市| 临武县| 南陵县| 太谷县| 美姑县| 安龙县| 曲麻莱县| 万宁市| 曲阳县| 曲阳县|