需要修改一个表中的两个字段,最开始定义变量时,decimal类型没有给定长度和小数位数,导致大于0小于1的数值始终体现为没有被更改,当时没有注意到所有的小数位数都是0。单独拿出来用update语句又可以改,纠结了很久,最后将游标里的修改语句记录下来才发现问题。decimal不给定长度和保留的小数位数时,只保留整数位。所以0.2这种最后就变成了0 ,不是没有被修改。
create procedure pro_up_price()
begin
declare v_erpid int;
declare v_batchnum int ;
declare v_drugsid int;
declare v_batchcode varchar(255);
declare flag int default 0; -- 声明标志变量
declare v_xsprice decimal(16,4) ;
declare v_cgprice decimal(16,4) ;
-- 声明游标
declare mc cursor for
select t.batchnum,t.erpid,t.batchcode,t.drugid,t.xsprice,t.cgprice from up_price t ;
-- 声明当fetch into 无结果时触发的语句 及修改标志变量为1
declare continue handler for not found set flag = 1;
-- 打开游标
open mc;
l2:loop -- 循环开始
-- 获取结果
fetch mc into v_batchnum,v_erpid,v_batchcode,v_drugsid , v_xsprice ,v_cgprice;
if flag=1 then -- 当无法fetch会触发handler continue
leave l2; -- 跳出循环
end if;
-- 这里执行修改操作
update jobstoragedrugs t set t.InPrice = v_cgprice,t.DrugsPrice = v_xsprice
where t.ErpId = v_erpid and t.DrugsID = v_drugsid and t.BatchNum = v_batchnum and t.BatchCode = v_batchcode;
-- 记录修改语句 把语句拼接为字符串存入一个临时表中,mysql没有打印到控制台的方法
insert into sql_yj values(CONCAT('update jobstoragedrugs t set t.InPrice =',cast(v_cgprice as char),',t.DrugsPrice=' , cast(v_xsprice as char) ,' where t.ErpId =' , cast(v_erpid as char) , ' and t.DrugsID =' , cast(v_drugsid as char) ,' and t.BatchNum =' , cast(v_batchnum as char) ,' and t.BatchCode =' , cast(v_batchcode as char) ));
end loop; -- 结束循环
-- 关闭游标
close mc;
end;
mysql拼接字符串使用concat('a','b','c') == abc
使用这个存储过程 : call pro_up_price();
如果需要修改,需要先删除原有存储过程 drop procedure pro_up_price ; 再重建