之前做了一个树的节点增加,有18位数,每两位一组,如下
00 00 00 00 00 00 00 00
需求如下
不考虑99后的数,从数据库中获取当前子节点的最新一条记录的编号
public class Tree {
public static void main(String[] args) {
String orgCode="101010391000000000";
}
public static Long createCode(String orgCode){
int index=orgCode.indexOf("00");//检测到第一个连续两个0的位置】、
String prefix="";
if(index!=-1){
prefix=orgCode.substring(0,index);
if(prefix.length()%2==0){//0到后面的数,是否是双数
//取出连续两个0的数的前面所有的数,取反的绝对值,然后补回18位数
//取反的意义是数字加1变负数,绝对值把数变正值,
//这些代码非常合适以后的订单编号,和一些英文与数字混合的时候使用
return Long.parseLong(Math.abs(~Long.parseLong(prefix))+String.format("%0"+(18-index+"d"),0));
}else{
return Long.parseLong(Math.abs(~Long.parseLong(prefix+"0"))+String.format("%0"+(17-index+"d"),0));
}
}else{
return Math.abs(~Long.parseLong(orgCode));
}
}
public static Long createFirstChileCode(String orgCode){
return Long.parseLong(orgCode.replaceFirst("00", "10"));
}
}
代码优化过几次,如果大家还可以优化得更好,不妨留言,相互交流