關(guān)于MySQL的整型數(shù)據(jù)的內(nèi)存溢出問(wèn)題的應(yīng)對(duì)方法
今天接到一個(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ǔ)空間:

另外請(qǐng)記著mysql的數(shù)據(jù)處理會(huì)轉(zhuǎn)成bigint處理,所以這里就用bigint幾個(gè)測(cè)試:
SELECTCAST(0ASUNSIGNED)-1; SELECT9223372036854775807+1;
MySQL 5.1 下:
mysql>SELECTCAST(0ASUNSIGNED)-1; +-------------------------+|CAST(0ASUNSIGNED)-1|+-------------------------+|18446744073709551615|+-------------------------+1ROWINSET(0.01 sec) mysql>SELECT9223372036854775807+1; +-------------------------+|9223372036854775807+1|+-------------------------+|-9223372036854775808|+-------------------------+1ROWINSET(0.01 sec)
MySQL 5.5, 5.6, 5.7下:
mysql>SELECTCAST(0ASUNSIGNED)-1; ERROR 1690(22003): BIGINTUNSIGNEDVALUEISOUTOF range IN'(cast(0 as unsigned) - 1)' mysql> mysql> mysql> mysql>SELECT9223372036854775807+1; ERROR 1690(22003): BIGINTVALUEISOUTOF range IN'(9223372036854775807 + 1)'
所在處理這類數(shù)據(jù)是一定要小心溢出(如早期有做弊沖Q幣就是利用這個(gè)方法處理)
這個(gè)問(wèn)題有可能會(huì)出現(xià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后版本
相關(guān)文章
MySQL定時(shí)全庫(kù)備份數(shù)據(jù)庫(kù)
數(shù)據(jù)備份真的很重要, 因?yàn)榭赡苡幸惶鞌?shù)據(jù)會(huì)被莫名其妙的刪掉了,本文主要介紹了MySQL定時(shí)備份數(shù)據(jù)庫(kù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
MySQL窗口函數(shù) over(partition by)的用法
本文主要介紹了MySQL窗口函數(shù) over(partition by)的用法, partition by相比較于group by,能夠在保留全部數(shù)據(jù)的基礎(chǔ)上,只對(duì)其中某些字段做分組排序,下面就來(lái)介紹一下具體用法,感興趣的可以了解一下2024-02-02
ubuntu linux下使用Qt連接MySQL數(shù)據(jù)庫(kù)的方法
Linux下完整的MySQL開發(fā)需要安裝服務(wù)器端,如果安裝客戶端也沒(méi)什么不好。直接在軟件中心搜mysql,把client和server選上。2011-08-08
詳解java調(diào)用ffmpeg轉(zhuǎn)換視頻格式為flv
這篇文章主要介紹了 詳解java調(diào)用ffmpeg轉(zhuǎn)換視頻格式為flv的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-09-09
MySQL入門(一) 數(shù)據(jù)表數(shù)據(jù)庫(kù)的基本操作
這類文章記錄我看MySQL5.6從零開始學(xué)》這本書的過(guò)程,將自己覺(jué)得重要的東西記錄一下,并有可能幫助到你們,在寫的博文前幾篇度會(huì)非?;A(chǔ),只要?jiǎng)邮智?,跟著我寫的例子全部?shí)現(xiàn)一遍,基本上就搞定了,前期很難理解的東西基本沒(méi)有2018-07-07

