之前做了一个树的节点增加,有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")); } }
代码优化过几次,如果大家还可以优化得更好,不妨留言,相互交流