最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

mybatis+mysql使用存储过程生成流水号的实现代码

来源:动视网 责编:小采 时间:2020-11-09 20:28:22
文档

mybatis+mysql使用存储过程生成流水号的实现代码

mybatis+mysql使用存储过程生成流水号的实现代码:使用存储过程,在操作数据库时开启事务,避免并发时同时操作造成数据重复 CREATE DEFINER=`root`@`localhost` PROCEDURE `GetSerialNo`(IN tsCode VARCHAR(50),OUT result VARCHAR(200) ) BEGIN DECLARE tsVal
推荐度:
导读mybatis+mysql使用存储过程生成流水号的实现代码:使用存储过程,在操作数据库时开启事务,避免并发时同时操作造成数据重复 CREATE DEFINER=`root`@`localhost` PROCEDURE `GetSerialNo`(IN tsCode VARCHAR(50),OUT result VARCHAR(200) ) BEGIN DECLARE tsVal


使用存储过程,在操作数据库时开启事务,避免并发时同时操作造成数据重复

CREATE DEFINER=`root`@`localhost` PROCEDURE `GetSerialNo`(IN tsCode VARCHAR(50),OUT result VARCHAR(200) )
BEGIN 
 DECLARE tsValue VARCHAR(50); 
 DECLARE tdToday VARCHAR(20); 
 DECLARE nowdate VARCHAR(20); 
 DECLARE tsQZ VARCHAR(50); 
 DECLARE t_error INTEGER DEFAULT 0; 
 DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET t_error=1; 
 START TRANSACTION; 
 /* UPDATE sys_sno SET sValue=sValue WHERE sCode=tsCode; */
 SELECT sValue INTO tsValue FROM sys_sno WHERE sCode=tsCode; 
 SELECT sQz INTO tsQZ FROM sys_sno WHERE sCode=tsCode ; 
 -- 因子表中没有记录,插入初始值 
 IF tsValue IS NULL THEN 
 SELECT CONCAT(DATE_FORMAT(NOW(),'%y%m'),'0001') INTO tsValue; 
 UPDATE sys_sno SET sValue=tsValue WHERE sCode=tsCode ; 
 SELECT CONCAT(tsQZ,tsValue) INTO result; 
 ELSE 
 SELECT SUBSTRING(tsValue,1,4) INTO tdToday; 
 SELECT CONVERT(DATE_FORMAT(NOW(),'%y%m'),SIGNED) INTO nowdate;
 -- 判断年月是否需要更新
 IF tdToday = nowdate THEN 
 SET tsValue=CONVERT(tsValue,SIGNED) + 1; 
 ELSE 
 SELECT CONCAT(DATE_FORMAT(NOW(),'%y%m') ,'0001') INTO tsValue ; 
 END IF; 
 UPDATE sys_sno SET sValue =tsValue WHERE sCode=tsCode; 
 SELECT CONCAT(tsQZ,tsValue) INTO result; 
 END IF; 
 IF t_error =1 THEN 
 ROLLBACK; 
 SET result = 'Error'; 
 ELSE 
 COMMIT; 
 END IF; 
 SELECT result ; 
END;
dao
Integer getFaultNo(Map<String, String> parameterMap);

xml

<update id="getFaultNo" parameterMap="getFaultMap" statementType="CALLABLE">
 CALL GetSerialNo(?,?)
 </update>
 <!--
 parameterMap.put("tsCode", 0);
 parameterMap.put("result", -1);
 -->
 <parameterMap type="java.util.Map" id="getFaultMap">
 <parameter property="tsCode" mode="IN" jdbcType="VARCHAR"/>
 <parameter property="result" mode="OUT" jdbcType="VARCHAR"/>
 </parameterMap>

调用

Map<String, String> parameterMap = new HashMap<String, String>();
 parameterMap.put("tsCode", "a");
 parameterMap.put("result", "-1");
 faultMapper.getFaultNo(parameterMap);
 // insert 故障日志 (主表)
 if (!parameterMap.get("result").equals("-1") && 
 !parameterMap.get("result").equals("Error")) {
 //成功
 } else {
 throw new RuntimeException();
 }

总结

以上所述是小编给大家介绍的mybatis+mysql 使用存储过程生成流水号的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

  • oracle(plsql)生成流水号
  • PHP获取MySQL执行sql语句的查询时间方法
  • ThinkPHP框架获取最后一次执行SQL语句及变量调试简单操作示例
  • mysql 获取今天、昨天0点时间戳的实例
  • mysql 获取昨天日期、今天日期、明天日期以及前一个小时和后一个小时的时间
  • sql 流水号获取代码实例
  • 文档

    mybatis+mysql使用存储过程生成流水号的实现代码

    mybatis+mysql使用存储过程生成流水号的实现代码:使用存储过程,在操作数据库时开启事务,避免并发时同时操作造成数据重复 CREATE DEFINER=`root`@`localhost` PROCEDURE `GetSerialNo`(IN tsCode VARCHAR(50),OUT result VARCHAR(200) ) BEGIN DECLARE tsVal
    推荐度:
    标签: 代码 mysql 流水号
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top