mysql存储过程怎么清除缓存以及 java for循环调用存储过程缓存机制

mybatis里调用存储过程产生缓存

DELIMITER $$

USE `pnc_newmes`$$

DROP PROCEDURE IF EXISTS `pr_creatembarcode`$$

CREATE DEFINER=`devmes`@`%` PROCEDURE `pr_creatembarcode`(
woCode VARCHAR(40), 
curData DATETIME,
OUT prCode VARCHAR(100), 
OUT errorCode VARCHAR(100)
)
BEGIN
   DECLARE WoCodes VARCHAR(40);
   DECLARE MaVerGds VARCHAR(100);
   DECLARE LineGds VARCHAR(100);
   DECLARE LastLevels INT(11);
   DECLARE LastModifyTimes DATETIME;
   DECLARE SerialRuleGds VARCHAR(100);
   DECLARE datas DATE;
   DECLARE F1s VARCHAR(255) DEFAULT NULL;
   DECLARE F2s VARCHAR(255) DEFAULT NULL;
   DECLARE F3s VARCHAR(255) DEFAULT NULL;
   DECLARE F4s VARCHAR(255)DEFAULT NULL;
   DECLARE LineCodes VARCHAR(40);
   DECLARE ys VARCHAR(10);
   DECLARE ms VARCHAR(10);
   DECLARE ds VARCHAR(10);
   DECLARE WOGDs VARCHAR(100);
   DECLARE t_error INTEGER DEFAULT 0; 
   SET @WoCodes=NULL,@t_error=0;
   SELECT woCode INTO @WoCodes;
   START TRANSACTION;
 
   SET @MaVerGds=NULL,@WOGDs=NULL,prCode=NULL;
   SELECT t1.MaVerGd,t1.Guid INTO @MaVerGds,@WOGDs FROM tpm_WoInfo t1  WHERE t1.woCode=@WoCodes;
   SET @LineGds=NULL;
   SELECT t2.LineGd INTO @LineGds FROM tpm_OrderLineInfo t2 WHERE t2.WOGD=@WOGDs;
   IF @MaVerGds='' OR @MaVerGds IS NULL THEN
      SELECT '物料版本不存在' INTO errorCode;
   ELSEIF @LineGds='' OR @LineGds IS NULL THEN
      SELECT '线体不存在' INTO errorCode;    
   ELSE 
    
      SET @F1s=NULL,@F2s=NULL,@F3s=NULL,@F4s=NULL;
      SELECT t3.F1,t3.F2,t3.F3,t3.F4 INTO @F1s,@F2s,@F3s,@F4s FROM tpm_MaPropertyInfo t3 WHERE t3.MaVerGd=@MaVerGds;
      SET @LastLevels=NULL,@LastModifyTimes=NULL,@SerialRuleGds=NULL;
      SELECT t6.LastLevel,t6.LastModifyTime,t5.SerialRuleGd INTO @LastLevels,@LastModifyTimes,@SerialRuleGds
      FROM tpm_MaVerInfo t5,tpm_SerialRuleInfo t6 WHERE  t5.Guid=@MaVerGds AND t6.Guid=t5.SerialRuleGd;
      SET @LineCodes=NULL;
      SELECT t4.LineCode INTO @LineCodes FROM tpm_LineInfo t4 WHERE t4.Guid=@LineGds;
      SET @datas=NULL,@ys=NULL,@ms=NULL,@ds=NULL;
      SET @datas=CURRENT_DATE;
      SET @ys=DATE_FORMAT(@datas,'%y')+18;
      SET @ms=DATE_FORMAT(@datas,'%m')+18;
      SET @ds=DATE_FORMAT(@datas,'%d')+18;
      SET @LastModifyTimes=DATE_FORMAT(@LastModifyTimes,'%Y-%m-%d');
  
      IF @F1s='' OR @F1s IS NULL THEN
         SELECT '晶硅类型及特殊电池制造技术不存在' INTO errorCode;
      ELSEIF @F2s='' OR @F2s IS NULL THEN
         SELECT '电池尺寸不存在' INTO errorCode;
      ELSEIF @F3s='' OR @F3s IS NULL THEN
         SELECT '导电芯板类型不存在' INTO errorCode;
      ELSE 
         CASE @F4s
       WHEN '00' THEN SET @F4s='T';
       WHEN '01' THEN SET @F4s='X';
       WHEN '02' THEN SET @F4s='Y';
       WHEN '03' THEN SET @F4s='Z';
           ELSE SET @F4s='0';
         END CASE;
         IF @LastModifyTimes!=@datas OR @LastModifyTimes IS NULL THEN
        UPDATE tpm_SerialRuleInfo SET LastModifyTime=NOW(),LastLevel=1 WHERE Guid=@SerialRuleGds;
        SET @LastLevels=0;
         ELSE
        UPDATE tpm_SerialRuleInfo SET LastModifyTime=NOW(),LastLevel=@LastLevels+1 WHERE Guid=@SerialRuleGds;
         END IF;
         SET @LastLevels=@LastLevels+1;
         IF @LastLevels<=9 THEN
        SELECT CONCAT(@F1s,@F2s,@F3s,@LineCodes,@ys,@ms,@ds,@F4s,'00',@LastLevels) INTO prCode;
         SET @t_error=1;
         ELSEIF @LastLevels<=99 THEN
         
        SELECT CONCAT(@F1s,@F2s,@F3s,@LineCodes,@ys,@ms,@ds,@F4s,'0',@LastLevels) INTO  prCode;
         SET @t_error=1;
         ELSE
        SELECT CONCAT(@F1s,@F2s,@F3s,@LineCodes,@ys,@ms,@ds,@F4s,@LastLevels) INTO prCode;  
         SET @t_error=1;
         END IF;
    
      END IF;    
  END IF;
  IF @t_error =1 THEN
    
    SELECT '1' INTO errorCode  ;
    SELECT prCode,errorCode;
    COMMIT;    
  ELSE 
    SELECT prCode,errorCode;
    ROLLBACK; 
  END IF;
END$$

DELIMITER ;

可以看到每当给变量赋值的时候,先给变量赋值为null;不然传入参数错误,也会返回值,原因就是变量会存储之前调用的值;

还可以看到我在传入参数里有个curData,这个就是方便java循环调用的时候传入一个当前时间因为当前时间在不停的变动,而java循环用mybatis调用存储过程时,传入参数不变不管循环多少次,只会拿第一次调用的值,因为传入参数一样,mybatis只会调用一次存储过程,后续调用都会直接在sqlSession里取值的;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值