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

小结

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

你可能感兴趣的:(mysql)