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

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

關(guān)于MySQL的整型數(shù)據(jù)的內(nèi)存溢出問題的應(yīng)對(duì)方法

2024-07-24 13:07:12
字體:
供稿:網(wǎng)友

這篇文章主要介紹了關(guān)于MySQL的整型數(shù)據(jù)的內(nèi)存溢出問題的應(yīng)對(duì)方法,作者還列出了MySQL所支持的整型數(shù)據(jù)的存儲(chǔ)空間支持大小,需要的朋友可以參考下

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

先看一下MySQL支持的整型數(shù)及大小,存儲(chǔ)空間:

關(guān)于MySQL的整型數(shù)據(jù)的內(nèi)存溢出問題的應(yīng)對(duì)方法

另外請(qǐng)記著mysql的數(shù)據(jù)處理會(huì)轉(zhuǎn)成bigint處理,所以這里就用bigint幾個(gè)測(cè)試:

 

 
  1. SELECTCAST(0ASUNSIGNED)-1; 
  2.  
  3. SELECT9223372036854775807+1; 

MySQL 5.1 下:

 

 
  1. mysql>SELECTCAST(0ASUNSIGNED)-1; 
  2. +-------------------------+|CAST(0ASUNSIGNED)-1|+-------------------------+|18446744073709551615|+-------------------------+1ROWINSET(0.01 sec) 
  3.  
  4. mysql>SELECT9223372036854775807+1; 
  5. +-------------------------+|9223372036854775807+1|+-------------------------+|-9223372036854775808|+-------------------------+1ROWINSET(0.01 sec) 

MySQL 5.5, 5.6, 5.7下:

 

 
  1. mysql>SELECTCAST(0ASUNSIGNED)-1; 
  2. ERROR 1690(22003): BIGINTUNSIGNEDVALUEISOUTOF range IN'(cast(0 as unsigned) - 1)' 
  3. mysql>  
  4. mysql>  
  5. mysql>  
  6. mysql>SELECT9223372036854775807+1; 
  7. ERROR 1690(22003): BIGINTVALUEISOUTOF range IN'(9223372036854775807 + 1)' 

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

這個(gè)問題有可能會(huì)出現(xiàn)積分消息,積分相加, 或是一些錢相關(guān)的業(yè)務(wù)中出現(xiàn), 主庫5.1 ,從庫MySQL 5.5情況也會(huì)出現(xiàn)不同步的問題。

建議:這類業(yè)務(wù)系統(tǒng)盡可能的升級(jí)到MySQL 5.5后版本

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 徐闻县| 山东省| 汝南县| 雷山县| 济南市| 综艺| 鄂托克旗| 乌恰县| 阜平县| 林芝县| 怀集县| 曲水县| 成都市| 任丘市| 启东市| 合水县| 宝山区| 安吉县| 北宁市| 新河县| 会泽县| 辽宁省| 曲麻莱县| 错那县| 衢州市| 修文县| 东山县| 定日县| 布尔津县| 建湖县| 黑山县| 隆安县| 丰原市| 班玛县| 龙川县| 怀化市| 新邵县| 金湖县| 凭祥市| 漠河县| 冕宁县|