MYSQL 存储过程中使用游标及字符串拼接

需要修改一个表中的两个字段,最开始定义变量时,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 ;  再重建

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL,有两种常用的方法可以进行字符串拼接。首先是使用`CONCAT`函数,它可以将多个字符串连接在一起。例如,`CONCAT('string1', 'string2', 'string3')`会返回一个由这三个字符串拼接而成的结果。这种方式是无缝拼接的。 其次是使用`CONCAT_WS`函数,它在拼接字符串时可以指定一个分隔符。例如,`CONCAT_WS('/', 'string1', 'string2', 'string3')`会返回一个由这三个字符串以斜杠作为分隔符拼接而成的结果。这种方式是带缝拼接的。 如果你想在MySQL存储过程进行字符串拼接,可以借助这两个函数来实现。下面是一个示例存储过程,演示了如何使用循环和查询来进行字符串拼接,并将结果更新到表的某一行记录。 首先,我们定义了一些变量,包括要拼接的字符串、查询结果的局部变量等等。然后,我们使用`DECLARE`语句定义了一个游标`report`,并通过`SELECT`语句从表查询数据。接着,我们使用`DECLARE CONTINUE HANDLER`语句设置了循环结束条件。然后,我们打开游标,并使用`FETCH`语句将查询结果赋值给相应的变量。接下来,我们使用`WHILE`循环进行拼接操作,将查询结果逐个拼接到字符串。最后,我们关闭游标,并使用`UPDATE`语句将拼接好的字符串更新到表的指定行记录。 通过这个示例,你可以根据自己的具体需求修改存储过程来完成字符串拼接的操作。希望对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值