亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL整型數(shù)據(jù)溢出的解決方法

 更新時(shí)間:2014年07月22日 11:03:39   作者:吳炳錫  
這篇文章主要介紹了MySQL整型數(shù)據(jù)溢出的解決方法,本文出現(xiàn)整型溢出的mysql版本是5.1,5.1下整型溢出不會(huì)報(bào)錯(cuò),而會(huì)變成負(fù)數(shù),需要的朋友可以參考下

今天接到一個(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è)試:

復(fù)制代碼 代碼如下:

SELECT CAST(0 AS UNSIGNED) - 1;

SELECT 9223372036854775807 + 1;

MySQL 5.1 下:

復(fù)制代碼 代碼如下:

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下:

復(fù)制代碼 代碼如下:

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é)

    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-08
  • mysql遞歸函數(shù)with?recursive的用法舉例

    mysql遞歸函數(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-08
  • mysql 控制臺(tái)程序的提示符 prompt 字符串設(shè)置

    mysql 控制臺(tái)程序的提示符 prompt 字符串設(shè)置

    mysql 控制臺(tái)程序的提示符 prompt 字符串設(shè)置,學(xué)習(xí)mysql的朋友可以參考下。
    2011-08-08
  • CMD命令操作MySql數(shù)據(jù)庫(kù)的方法詳解

    CMD命令操作MySql數(shù)據(jù)庫(kù)的方法詳解

    今天小編就為大家分享一篇關(guān)于CMD命令操作MySql數(shù)據(jù)庫(kù)的方法詳解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-02-02
  • MySQL中表子查詢與關(guān)聯(lián)子查詢的基礎(chǔ)學(xué)習(xí)教程

    MySQL中表子查詢與關(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-12
  • MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解

    MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解

    這篇文章主要介紹了MySQL與JDBC之間的SQL預(yù)編譯技術(shù)講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • mysql 常用命令集錦[絕對(duì)精華]

    mysql 常用命令集錦[絕對(duì)精華]

    測(cè)試環(huán)境:mysql 5.0.45 【注:可以在mysql中通過(guò)mysql> SELECT VERSION();來(lái)查看數(shù)據(jù)庫(kù)版本】
    2009-06-06
  • mysql socket文件作用詳解

    mysql socket文件作用詳解

    這篇文章主要介紹了mysql socket文件作用的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • mysql實(shí)現(xiàn)sequence功能的代碼

    mysql實(shí)現(xiàn)sequence功能的代碼

    今天小編就為大家分享一篇關(guān)于mysql實(shí)現(xiàn)sequence功能的代碼,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-03-03
  • MySQL存儲(chǔ)過(guò)程中游標(biāo)循環(huán)的跳出和繼續(xù)操作示例

    MySQL存儲(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

最新評(píng)論