Mybatis+mysql uses stored procedures to generate serial number implementation code

Mybatis+mysql uses stored procedures to generate serial number implementation code

Use stored procedures to start transactions when operating the database to avoid data duplication caused by concurrent operations

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; 
 -- There is no record in the factor table, insert the initial value 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;
   -- Determine whether the year and month need to be updated 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>

Call

Map<String, String> parameterMap = new HashMap<String, String>();
  parameterMap.put("tsCode", "a");
  parameterMap.put("result", "-1");
  faultMapper.getFaultNo(parameterMap);
  // insert failure log (main table)
  if (!parameterMap.get("result").equals("-1") && 
    !parameterMap.get("result").equals("Error")) {
   //Success} else {
   throw new RuntimeException();
  }

Summarize

The above is the implementation code of mybatis+mysql using stored procedures to generate serial numbers introduced by the editor. I hope it will be helpful to everyone. If you have any questions, please leave me a message and the editor will reply to you in time. I would also like to thank everyone for their support of the 123WORDPRESS.COM website!

You may also be interested in:
  • How to use Mysql stored procedures in Mybatis
  • mysql+mybatis implements stored procedure + transaction + multi-concurrent serial number acquisition

<<:  Summary of Linux user groups and permissions

>>:  Steps to introduce PWA into Vue project

Recommend

CSS Standard: vertical-align property

<br />Original text: http://www.mikkolee.com...

MySQL aggregate function sorting

Table of contents MySQL result sorting - Aggregat...

Using zabbix to monitor the ogg process (Linux platform)

The ogg process of a database produced some time ...

Solution to incomplete text display in el-tree

Table of contents Method 1: The simplest way to s...

Solution to Nginx 500 Internal Server Error

Today, when I was using Nginx, a 500 error occurr...

Detailed introduction of Chrome developer tools-timeline

1. Overview Users expect the web applications the...

MySQL DML language operation example

Additional explanation, foreign keys: Do not use ...

How to enable Flash in Windows Server 2016

I recently deployed and tested VMware Horizon, an...

How to deploy FastDFS in Docker

Install fastdfs on Docker Mount directory -v /e/f...

An article teaches you JS function inheritance

Table of contents 1. Introduction: 2. Prototype c...

Detailed steps to install Mysql5.7.19 using yum on Centos7

There is no mysql by default in the yum source of...

Implementing a puzzle game with js

This article shares the specific code of js to im...

MySQL 5.6 zip package installation tutorial detailed

Previously, we all used files with the suffix .ms...