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

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

存储过程部分代码如下

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)即可。

小结

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

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值