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
  • asp之家 软件编程 m.aspxhome.com