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


猜你喜欢
- 向上转型:子类对象转为父类,父类可以是接口。公式:Father f = new Son();Father是父类或接口,son是子类。向下转型
- 一、一对一关联 1.1、提出需求根据班级id查询班级信息(带老师的信息)1.2、创建表和数据创建一张教师表和班级表,这里我们假设一
- springboot static调用service为null@PostConstruct注解好多人以为是Spring提供的。其实是Java
- 需求在配置类中,从application.properties中读取一个复杂list。如List<Person>或者初始化一个m
- //路径, 添加开机启动/删除开机启动 public s
- mybatis-plus今天遇到一个问题,就是mybatis 没有读取到mapper.xml 文件。特此记录一下,问题如下:at com.b
- 基本要点1、定义根据百度百科的定义,RESTFUL是一种网络应用程序的设计风格和开发方式2、传统方式与Restful风格的区别在我们学习re
- 零、插播2020CSDN博客之星投票新闻近日(1月11日-1月24日),2020CSDN博客之星评选正在火热进行中,作为码龄1年的小白有幸入
- 今天突发奇想,想做一个智能拼图游戏来给哄女友。需要实现这些功能第一图片自定义第二宫格自定义,当然我一开始就想的是3*3 4*4 5*5,没有
- 1.由于需要删除文件,因此需要如下权限: <uses-permission android:name="android.pe
- Java 序列化和反序列化实例详解在分布式应用中,对象只有经过序列化才能在各个分布式组件之间传输,这就涉及到两个方面的技术-发送者将对象序列
- 在同一个类中: 对于静态方法,其他的静态或非静态方法都可以直接调用它。而对于非静态方法,其他的非静态方法是可以直接调用它的。但是其他静态方法
- 本文所述为一个C#使用iCSharpcode压缩的使用类,经测试效果不错。分享给大家供大家参考之用。具体方法如下:1.参数类using Sy
- 类加载机制java类从被加载到JVM到卸载出JVM,整个生命周期包括:加载(Loading)、验证(Verification)、准备(Pre
- 1 需求描述我们现在要干一个什么事情呢,我们要在浏览器输入一个请求地址,然后我们的后端就给我返回一个User对象即可,并且我希望以Json的
- 直接上代码:@Testpublic void testUnicode() { String a = "Hello&qu
- 一、OutputStreamWriter流 API说明:OutputStreamWriter是从字符流到
- 本文实例讲述了Java泛型的使用限制。分享给大家供大家参考,具体如下:一 什么情况下不能使用泛型1 不能使用泛型的形参创建对象。T o=ne
- 接口:官方的含义是---->java接口是一系列方法的声明,是一些方法特征的集合疑问:那为什么不用抽象类呢?把他们共有的方法集合起来放
- 本文实例为大家分享了unity鼠标或者手指点击模型播放动的具体代码,供大家参考,具体内容如下using UnityEngine;using