package com.consum.base.core; import com.walker.jdbc.service.BaseServiceImpl; import org.springframework.stereotype.Service; import java.util.List; /** * 编码统一生成服务 */ @Service public class CodeGeneratorService extends BaseServiceImpl { /** * 获取仓库编码 * * @return 仓库编码规则为:WH+四位数字连号(0001) */ public String createWarehouseCode() { // TODO: 10/10/2023 获取仓库编码 String CODE_PREFIX = CodeGeneratorEnum.Warehouse.getValue(); /* 1.SELECT CODE_INDEX from BASE_CODE_INDEXING where CODE_PREFIX=:CODE_PREFIX CODE_PREFIX是"WH" 如果获取不到,就从1开始,但需要补全前面的"0"返回 "0001";同时需要插入数据库 insert BASE_CODE_INDEXING CODE_INDEX=1 CODE_PREFIX是="WH" where CODE_PREFIX=:CODE_PREFIX; 2.如果能够获取到,则将CODE_INDEX=CODE_INDEX+1后更新到数据库,补全前面的"0"返回 "0001" */ return null; } /** * 连续获取多个仓库编码 * * @return 仓库编码规则为:WH+四位数字连号(0001) */ public List createWarehouseCodeList(int count) { // TODO: 10/10/2023 获取仓库编码 String CODE_PREFIX = CodeGeneratorEnum.Warehouse.getValue(); /* 1.SELECT CODE_INDEX from BASE_CODE_INDEXING where CODE_PREFIX=:CODE_PREFIX CODE_PREFIX是"WH" 如果获取不到,就从1开始,但需要补全前面的"0"返回 "0001";同时需要插入数据库 insert BASE_CODE_INDEXING CODE_INDEX=1 CODE_PREFIX是="WH" where CODE_PREFIX=:CODE_PREFIX; 2.如果能够获取到,则将CODE_INDEX=CODE_INDEX+1后更新到数据库,补全前面的"0"返回 "0001" */ return null; } /** * 生成物品编码 * * @param classify A,B,C * @param type 1=集采;2=自采 * @return 共8位, 一位物品分类(A/B/C)+一位类型(1为集采,2为自采)+6位连续数字号 */ public String createGoodsTemplateCode(String classify, int type) { String prefix = classify + Integer.valueOf(type).toString(); /* 1.SELECT CODE_INDEX from BASE_CODE_INDEXING where CODE_PREFIX=:CODE_PREFIX CODE_PREFIX是 prefix 如果获取不到,就从1开始,但需要补全前面的"0"返回 "000001";同时需要插入数据库 insert BASE_CODE_INDEXING CODE_INDEX=1 CODE_PREFIX是=:prefix where CODE_PREFIX=:CODE_PREFIX; 2.如果能够获取到,则将CODE_INDEX=CODE_INDEX+1后更新到数据库,补全前面的"0"返回 "000001" */ return null; } /** * 根据前缀获取业务表单编码 * * @param codeGeneratorEnum CodeGeneratorEnum * @return 1.两位前缀(如:CG代表采购单)+六位年月日(230226:23年2月26日)+四位数字连号(0002) */ public String createBusinessFormCode(CodeGeneratorEnum codeGeneratorEnum) { return null; } }