在你生成订单编号的位置将 autoInt 加 1 再拼接到订单编号的末尾 ,这样的话,你每调用一次生成订单编号,就会加 1
// 生成不重复的订单编号
public static String getOrder() {
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMddHHmmSS");
Date date = new Date();
autoInt++;
String s = simpleDateFormat.format(date) + autoInt;
System.out.println("订单编号为:"+s);
return s;
}
比如我本来的订单编号是:20211119180797
调用了这个方法后就变成了 202111191807972
再次调用就变成了 202111191807973,以此类推
以上方法是我想到的不用去对数据库进行操作的方法,本人使用 mysql 数据库,你也可以使用其他方法如\*\*主键自增序列\*\*,这个对于 mysql 比较难弄,对于 oracle 比较容易。
这里再说一下, java 静态变量,在服务器重新启动的时候就会恢复默认值,这个不用担心,因为,我们的时间戳是不断变化的,所以即使恢复到 1 也不会重复