注意:调用使用mybatis-plus3形式调用,可能会有些区别
1. 创建存储过程
-- -- 生成员工工号的存储过程
DELIMITER $$
CREATE PROCEDURE generate_employee_number(OUT employeeNumber VARCHAR(20)) -- 解释 out 一个返回值
BEGINDECLARE prefix VARCHAR(3) DEFAULT '000'; -- 解释 准备一个固定前缀DECLARE next_id INT; -- 解释 后缀值SELECT AUTO_INCREMENT -- 解释 这里的sql就是 拿到staff表中下一个自增的值 赋值 给 next_id [前提: staff主键是自增情况]INTO next_idFROM information_schema.tablesWHERE table_schema = DATABASE()AND table_name = 'staff'; SET employeeNumber = CONCAT(prefix, next_id); -- 解释 赋值给 employeeNumber
END$$
DELIMITER ;-- 删除存储过程
DROP PROCEDURE generate_employee_number;CALL generate_employee_number(@employeeNumber); -- 测试
SELECT @employeeNumber;SHOW CREATE PROCEDURE generate_employee_number; -- 判断是否存在SELECT DATABASE(); -- 判断当前正在操作的数据库
2.xml调用存储过程
<!--调用存储过程-->
<select id="generateEmployeeNumber" statementType="CALLABLE">{call generate_employee_number(#{employeeNumber, mode=OUT, jdbcType=VARCHAR, javaType=java.lang.String})}
</select>
3. mapper类
void generateEmployeeNumber(Map<String, Object> result);
4. controller 或 测试
Map<String, Object> result = new HashMap<>();
result.put("employeeNumber", null);staffMapper.generateEmployeeNumber(result); // 调用存储过程生成员工编号System.out.println("result = " + result.get("employeeNumber"));... ...