树的节点增加

之前做了一个树的节点增加,有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"));
		
	}
}

 代码优化过几次,如果大家还可以优化得更好,不妨留言,相互交流

猜你喜欢

转载自81680252.iteye.com/blog/2269630
今日推荐