加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql应用关于MySQL的整型数据的内存溢出问题的应对方法

发布时间:2020-12-12 03:11:23 所属栏目:MySql教程 来源:网络整理
导读:《Mysql应用关于MySQL的整型数据的内存溢出问题的应对方法》要点: 本文介绍了Mysql应用关于MySQL的整型数据的内存溢出问题的应对方法,希望对您有用。如果有疑问,可以联系我们。 MYSQL教程 今天接到一个朋友电话说是觉的数据库被别人更改了,出现数据不对的

《Mysql应用关于MySQL的整型数据的内存溢出问题的应对方法》要点:
本文介绍了Mysql应用关于MySQL的整型数据的内存溢出问题的应对方法,希望对您有用。如果有疑问,可以联系我们。

MYSQL教程今天接到一个朋友电话说是觉的数据库被别人更改了,出现数据不对的问题 .经过很久的排查是数据类型溢出了(发生问题的版本是MySQL 5.1).后来通过给朋友那边把MySQL 5.1升级到MySQL 5.5去解决这个问题. 这也让我有兴趣去了解一下MySQL不同版本数据类型溢出的处理机制.

MYSQL教程先看一下MySQL支持的整型数及大小,存储空间:

MYSQL教程

MYSQL教程另外请记着mysql的数据处理会转成bigint处理,所以这里就用bigint几个测试:

MYSQL教程
SELECTCAST(0ASUNSIGNED)-1;
 
SELECT9223372036854775807+1;

MYSQL教程MySQL 5.1 下:

MYSQL教程
mysql>SELECTCAST(0ASUNSIGNED)-1;
+-------------------------+|CAST(0ASUNSIGNED)-1|+-------------------------+|18446744073709551615|+-------------------------+1ROWINSET(0.01 sec)
 
mysql>SELECT9223372036854775807+1;
+-------------------------+|9223372036854775807+1|+-------------------------+|-9223372036854775808|+-------------------------+1ROWINSET(0.01 sec)

MYSQL教程MySQL 5.5,5.6,5.7下:

MYSQL教程
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)'

MYSQL教程所在处理这类数据是一定要小心溢出(如早期有做弊冲Q币就是利用这个方法处理)

MYSQL教程这个问题有可能会出现积分消息,积分相加, 或是一些钱相关的业务中出现,主库5.1 ,从库MySQL 5.5情况也会出现不同步的问题.
建议:这类业务系统尽可能的升级到MySQL 5.5后版本 

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读