java自动生成编号的实现(格式:yyMM+四位流水号)
作者:hj_西门吹雪 时间:2023-10-10 09:24:36
本篇文章主要介绍了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
标签:java,自动生成编号
0
投稿
猜你喜欢
Android build文件的删除的方法
2022-12-28 12:40:17
Android中URLEncoder空格被转码为"+"号的处理办法
2022-02-09 17:58:12
c# mutex互斥量的深入解析
2022-03-13 02:38:42
Android开发之SeekBar基本使用及各种美观样式示例
2023-06-30 07:15:22
Java实现商城订单超时取消功能
2023-09-17 06:20:42
Mybatis 中的sql批量修改方法实现
2022-12-10 23:36:51
c#中LINQ的基本用法(三)
2022-11-29 11:06:31
Path类 操作文件类的实例
2023-09-27 12:53:33
Android开发之图片压缩工具类完整实例
2023-07-02 10:22:08
Android 仿今日头条评论时键盘自动弹出的效果(推荐)
2022-07-24 15:00:45
解决IDEA和CMD中java命令提示错误: 找不到或无法加载主类的问题
2023-09-19 02:31:16
Java实现分解任意输入数的质因数算法示例
2022-07-29 23:07:08
详解Java中的数组与字符串相关知识
2023-02-10 03:31:10
Java选择排序和垃圾回收机制详情
2023-10-23 16:53:38
Java中的break和continue关键字的使用方法总结
2022-07-13 11:50:46
Java中的内部类使用详情
2022-07-24 05:09:38
Android实现自定义圆形进度条
2022-10-28 04:55:22
JavaWeb Spring依赖注入深入学习
2022-04-02 08:20:05
Java中lambda表达式的基本运用
2023-09-09 08:02:36
Java接口RandomAccess全面了解
2023-09-11 19:05:29