在项目中,如何根据当前的流水号,生成下一个流水号!

2024-09-08 04:08
文章标签 项目 生成 当前 流水号

本文主要是介绍在项目中,如何根据当前的流水号,生成下一个流水号!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在项目中,如何根据当前的流水号,生成下一个流水号!

DataType.java

package cn.itcast.crm.util;import org.apache.commons.lang.StringUtils;public class DataType {/*** 利用给定的流水位生成第一个流水号* 流水位3 ----- 001 * 流水位4-----0001*/public static String geneFirstGlideNumber(Integer glideBit) {if(glideBit==null||glideBit<3){glideBit=3;}String glideNumber="";for(int i=0;i<glideBit-1;i++){glideNumber=glideNumber+"0";}glideNumber=glideNumber+"1";return glideNumber;}/*** 根据当前的流水号,生成下一个流水号* 当前是001 下一个002* 当前是005 下一个006* @param curGlideNumber 当前的流水号* @return* String 10005  ----整形	 10005* 整形 10005+1    ----整形 10006* 整形10006      ----String 10006* String 10006  ----截取 0006*/public static String geneNextGlideNumber(String curGlideNumber) {if(StringUtils.isBlank(curGlideNumber)){throw new RuntimeException("不能计算下一个流水号");}curGlideNumber="1"+curGlideNumber;Integer icurGlideNumber=Integer.parseInt(curGlideNumber);icurGlideNumber++;curGlideNumber=icurGlideNumber+"";curGlideNumber=curGlideNumber.substring(1);return curGlideNumber;}public static void main(String[] args) {System.out.println(geneNextGlideNumber("004"));}}

CompanyServiceImpl.java

package cn.itcast.crm.service.impl;import java.util.Date;
import java.util.List;import javax.annotation.Resource;import org.apache.commons.lang.time.DateFormatUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Isolation;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;import cn.itcast.crm.dao.ISysCodeRuleDao;
import cn.itcast.crm.domain.SysCodeRule;
import cn.itcast.crm.service.ICompanyService;
import cn.itcast.crm.util.DataType;@Transactional(readOnly=true)
@Service(ICompanyService.SERVICE_NAME)
public class CompanyServiceImpl implements ICompanyService {@Resource(name=ISysCodeRuleDao.SERVICE_NAME)private ISysCodeRuleDao sysCodeRuleDao;@Transactional(isolation=Isolation.DEFAULT,propagation=Propagation.REQUIRED,readOnly=false)public String getCompanyCodeByTabName(String tabName) {//获取代码规则,查询sys_code_ruleString whereHql=" and o.tabName=?";Object[] params={tabName};List<SysCodeRule> list=sysCodeRuleDao.findObjectByConditionWithNoPage(whereHql, params);if(list==null||list.size()!=1){throw new RuntimeException("不能生成客户的编码");}SysCodeRule sysCodeRule=list.get(0);//* 获取 是否被修改过或新添加的 字段的值  //* 如果  是否被修改过或新添加的=='Y'  if(sysCodeRule.getAvailable().equals("Y")){//* 获取 流水位=3Integer glideBit=sysCodeRule.getGlideBit();//* 生成第一个流水号 001String firstGlideNumber=DataType.geneFirstGlideNumber(glideBit);//* 计算下一个流水号 002String nextGlideNumber=DataType.geneNextGlideNumber(firstGlideNumber);//* 获取系统的当前时间 格式yyyyMMdd  20110914String curDate=DateFormatUtils.format(new Date(), "yyyyMMdd");//* 生成客户编码//* 编码前缀+"-"+利用日期位格式生成当前的日期[yyyy-MM-dd ]+"-"+001  c-2011-09-14-001String code=sysCodeRule.getAreaPrefix()+"-"+DateFormatUtils.format(new Date(), sysCodeRule.getAreaTime())+"-"+firstGlideNumber;//* 修改代码规则表//*  下一个序列号="002"sysCodeRule.setNextseq(nextGlideNumber);//*  当前日期  20110914sysCodeRule.setCurDate(curDate);//*  是否被修改过='N' sysCodeRule.setAvailable("N");sysCodeRuleDao.update(sysCodeRule);//System.out.println("1:code:"+code);return code;}else{  //是否被修改过或新添加的=='N'  //* 获取代码规则表中的当前日期字段的值String curDate=sysCodeRule.getCurDate();//* 获取系统的当前日期、String sysCurDate=DateFormatUtils.format(new Date(), "yyyyMMdd"); //* 如果代码规则表中的当前日期字段的值==系统的当前日期、if(curDate.equals(sysCurDate)) {//* 获取下一个序列号 ="002"String nextseq=sysCodeRule.getNextseq();//* 计算新的流水号 003String nextGlideNumber=DataType.geneNextGlideNumber(nextseq);//* 生成客户编码//* 编码前缀+"-"+利用日期位格式生成当前的日期[yyyy-MM-dd ]+"-"+001 String code=sysCodeRule.getAreaPrefix()+"-"+DateFormatUtils.format(new Date(), sysCodeRule.getAreaTime())+"-"+nextseq;//* 修改代码规则表//*  下一个序列号="003"sysCodeRule.setNextseq(nextGlideNumber);//*  当前日期  20110914//*  是否被修改过='N' sysCodeRuleDao.update(sysCodeRule);//System.out.println("2:code:"+code);return code;}else{ //如果代码规则表中的当前日期字段的值!=系统的当前日期、//* 获取 流水位=3   Integer glideBit=sysCodeRule.getGlideBit();//* 生成第一个流水号 001String firstGlideNumber=DataType.geneFirstGlideNumber(glideBit);//* 计算下一个流水号 002String nextGlideNumber=DataType.geneNextGlideNumber(firstGlideNumber);//* 生成客户编码//* 编码前缀+"-"+利用日期位格式生成当前的日期[yyyy-MM-dd ]+"-"+001 String code=sysCodeRule.getAreaPrefix()+"-"+DateFormatUtils.format(new Date(), sysCodeRule.getAreaTime())+"-"+firstGlideNumber;//* 修改代码规则表//*  下一个序列号="002"sysCodeRule.setNextseq(nextGlideNumber);//*  当前日期  20110915sysCodeRule.setCurDate(sysCurDate);//*  是否被修改过='N' sysCodeRule.setAvailable("N");sysCodeRuleDao.update(sysCodeRule);//System.out.println("3:code:"+code);return code;}}
}
}
利用上面的代码,就可以自动生成流水号。



这篇关于在项目中,如何根据当前的流水号,生成下一个流水号!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147071

相关文章

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小