Warning(1265)Data truncated for column 'v_mmi' at row 1

本文详细介绍了在MySQL存储过程中,因变量长度设置不当导致数据截断的问题,并提供了修改方法。重点在于理解MySQL字段类型限制及其对数据存储的影响,以及如何避免常见的数据丢失错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天准备优化一个项目的查询。欲在创建帐号的存储过程中增加一个日期索引,在执行该存储过程时发现以下警告信息:

存储过程部分代码如下

BEGIN
declare uid int default 0;
declare v_password char(32);
declare v_mmi char(32);
declare v_date date default curdate();
declare v_time timestamp default CURRENT_TIMESTAMP;
DECLARE exit HANDLER FOR SQLSTATE '23000' select uid;
set v_password=md5("123456");
set v_mac=UCASE(v_mac);
set v_imei=UCASE(v_imei);
set v_mmi=concat(v_mobile,v_mac,v_imei);
if v_mmi<>"" then
  set v_mmi=md5(v_mmi);
  ...
end if;
...
END

出现Warning(1265)Data truncated for column 'v_mmi' at row 1错误的原因:

由于定义v_mmi为char(32),因为当初考虑,该值是由md5加密的值,所以长度正好为32。但是没有考虑到,v_mobile、v_mac、v_imei这三者连接后的长度已经超过32字符,所以mySQL显示警告信息“Warning(1265)Data truncated for column 'v_mmi' at row 1”,表明数据被截断。

修改方法

将定义v_mmi的数据类型改为char(50)即可。

小结

普通的向数据库插入数据,还是在存储过程中定义的变量,其值类型及长度都不能超出所定义字段类型及范围。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值