用递归解决连续更换信息找到最新信息的问题

工作中遇到连续更换电话或者账户的问题,需要通过其中任意一个来找到最后一次更新结果。

因为是连续更新,在旧信息和新信息字段内都有记录,所以,用了递归来解决这个问题。最近比较喜欢用递归,感觉比循环用起来漂亮。

/**
	 * @param
	 * 动态查询,如果介质变更,根据旧的介质号,查询新介质号;如果电话变更,则根据旧电话查询新电话
	 * oldinfo:原有信息,newCol:新信息字段;checkSql:检查的sql
* */
	private String infoChange(String oldInfo,String newCol,String checkSql ){
		//用newList接收通过旧信息查询出来的新信息
		List<Map<String, Object>> newList  = JdbcSupportDAO.getJdbcTemplate().queryForList(checkSql);
		if(newList.size()>0){
			String newInfo = "";
			try {
				//只有一条返回结果时,获取新的信息
				newInfo = (String) newList.get(0).get(newCol);
			} catch (Exception e) {
				logger.error("信息更换查询有误,请核对信息为:"+oldInfo+"的更换记录。");
			}finally{
				//递归调用该方法,将查询到的新信息返回
				return infoChange(newInfo,newCol,checkSql);
			}
		}else{
			return oldInfo;
		}
	}

SQL作为参数传入,调用时候增强了灵活性。简化一下大概是这个样子(伪代码)。

private String getLastInfo(String oldInfo){
	
		//通过旧信息查询新信息的方法
		Strng newInfo = getNewInfo(oldInfo);
		if(oldInfo!=newInfo){
			return  getLastInfo(newInfo);
		}
		}else{
			return newInfo;
		}
	}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值