树的节点增加

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值