java自动生成编号的实现(格式:yyMM+四位流水号)
作者:hj_西门吹雪 发布时间:2023-10-10 09:24:36
标签:java,自动生成编号
本篇文章主要介绍了java自动生成编号的实现,分享给大家,具体如下
/**
* 自动生成编号格式:yyMM+四位流水号
*/
@RequestMapping(params = "createCode")
@ResponseBody
public AjaxJson createCode(HttpServletRequest request, String tableName,
String fieldName) {
AjaxJson j = new AjaxJson();
String sql = "select Max(a." + fieldName + ") max_code from "
+ tableName + " a ";
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
list = jdbcTemplate.queryForList(sql);
// System.out.println("最大编号:"+list.get(0).get("max_comment_code"));
String comment_code = "";
String max_code = "";
if (list.size() > 0) {
max_code = (String) list.get(0).get("max_code");
}
SimpleDateFormat format = new SimpleDateFormat("yyMM"); // 时间字符串产生方式
String uid_pfix = format.format(new Date()); // 组合流水号前一部分,时间字符串,如:1601
System.out.println("time=" + format.format(new Date()));
if (max_code != null && max_code.contains(uid_pfix)) {
String uid_end = max_code.substring(4, 8); // 截取字符串最后四位,结果:0001
// System.out.println("uid_end=" + uid_end);
int endNum = Integer.parseInt(uid_end); // 把String类型的0001转化为int类型的1
// System.out.println("endNum=" + endNum);
int tmpNum = 10000 + endNum + 1; // 结果10002
// System.out.println("tmpNum=" + tmpNum);
comment_code = uid_pfix + UtilMethod.subStr("" + tmpNum, 1);// 把10002首位的1去掉,再拼成1601260002字符串
} else {
comment_code = uid_pfix + "0001";
}
// System.out.println(comment_code);
Map<String, Object> map = new HashMap<String, Object>();
map.put("msg", comment_code);
j.setAttributes(map);
return j;
}
//公共方法
public class UtilMethod {
/*
* 把10002首位的1去掉的实现方法:
* @param str
* @param start
* @return
*/
public static String subStr(String str, int start) {
if (str == null || str.equals("") || str.length() == 0)
return "";
if (start < str.length()) {
return str.substring(start);
} else {
return "";
}
}
}
前端:
//自动生成编号;格式:yyMM0001
function createCode() {
var id = $("[name='id']").val();
// alert(id.length);
if(id.length<=0){
var a="";
$.ajax({
async : false,
cache : false,
type : 'POST',
contentType : 'application/json',
dataType:"json",
url : "Controller.do?createCode&tableName=表名&fieldName=字段名",
error : function() {
alert('出错了');
frameElement.api.close();
},
success : function(data) {
a=data.attributes.msg;
}
});
//alert(a);
$("#check_task_code").val(a);
}
}
来源:https://blog.csdn.net/jianqiangdexiaohai/article/details/81240176
0
投稿
猜你喜欢
- spring.thymeleaf.cache=false不起作用配置是清除缓存,实现热部署。也就是修改了html后不用重启,刷新页面就能看到
- 本文实例讲述了C#调用存储过程的方法。分享给大家供大家参考,具体如下:CREATE PROCEDURE [dbo].[GetNameById
- 功能:解决web站点的登录,权限验证,授权等功能优点:在不影响站点业务代码,可以权限的授权与验证横切到业务中1、要添加的依赖<!--t
- -vmargs -Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M 这里有几个问
- 1.导入jar包: <!--jmsTemplate--> <dependency> <
- 项目中肯定会遇到异步调用其他方法的场景,比如有个计算过程,需要计算很多个指标的值,但是每个指标计算的效率快慢不同,如果采用同步执行的方式,运
- 下面我们就字符串连接方面分析。1.String打开String的源码,如图所示会发现存储字符串的字符数值是final常量。再看String的
- 注意我这里用的是官方最稳定的版本3.7.1,版本之间有个别命令是有差距的!1.zkCli.sh客户端zkCli.sh可以理解成客户端,也可以
- 前言对于数组遍历,基本上每个开发者都写过,遍历本身没什么好说的,但是当我们在遍历的过程中,有一些复杂的业务逻辑时,将会发现代码的层级会逐渐加
- 这篇文章主要介绍了SpringBoot下如何实现支付宝接口的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值
- 前言研究表明,Java堆中对象占据最大比重的就是字符串对象,所以弄清楚字符串知识很重要,本文主要重点聊聊字符串常量池。Java中的字符串常量
- 本章概要返回JSON数据静态资源访问返回JSON数据默认实现JSON 是目前主流的前后端数据传输方式,Spring MVC中使用消息转换器H
- 1.封装分页Page类package com.framework.common.page.impl;import java.io.Seria
- 1、首先导入solrj需要的的架包2、需要注意的是低版本是solr是使用SolrServer进行URL实例的,5.0之后已经使用SolrCl
- 预加载bean在springBoot启动过程中就完成创建加载在AbstractApplicationContext的refresh方法中//
- 摘要:vs2019新鲜出炉,配置opencv又有哪些不一样呢,这个教程将会一步一步的教你如何配置opencv和跑动opencv一个简单的项目
- 在传统的Java编程中,被广为人知的一个知识点是:java Interface接口中不能定义private私有方法。只允许我们定义publi
- Java ThreadPoolExecutor的参数深入理解一、使用Executors创建线程池 &nb
- 正常在Java工程中读取某路径下的文件时,可以采用绝对路径和相对路径,绝对路径没什么好说的,相对路径,即相对于当前类的路径。在本地工程和服务
- 在J2EE项目的开发中,不管是对底层的数据库操作过程,还是业务层的处理过程,还是控制层的处理过程,都不可避免会遇到各种可预知的、不可预知的异