问题描述
数据库中的电话号码已加密,因此我必须使用解密功能。所以我写了这样的代码,但是没有用。我该怎么做?
这是我的代码
BooleanBuilder builder = new BooleanBuilder();
if(StringUtils.hasText(memberVO.getSearchTypeCd()) && StringUtils.hasText(memberVO.getSearchText())) {
if(memberVO.getSearchTypeCd().equals("memNm")) {
builder.and(info.memNm.contains(memberVO.getSearchText()));
}
if(memberVO.getSearchTypeCd().equals("nickNm")) {
builder.and(info.nickNm.contains(memberVO.getSearchText()));
}
if(memberVO.getSearchTypeCd().equals("hpNo")) {
//FN_DECRYPT is not working
builder.and(info.nickNm.prepend("FN_DECRYPT(").append(")").contains(memberVO.getSearchText()));
}
}
WHERE FN_DECRYPT(hpNo) LIKE '%010-0000-0000%'
谢谢。
解决方法
最后我解决了
BooleanBuilder builder = new BooleanBuilder();
if(StringUtils.hasText(memberVO.getSearchTypeCd()) && StringUtils.hasText(memberVO.getSearchText())) {
if(memberVO.getSearchTypeCd().equals("memNm")) {
builder.and(info.memNm.contains(memberVO.getSearchText()));
}
if(memberVO.getSearchTypeCd().equals("nickNm")) {
builder.and(info.nickNm.contains(memberVO.getSearchText()));
}
if(memberVO.getSearchTypeCd().equals("hpNo")) {
builder.and(Expressions.booleanTemplate("FN_DECRYPT({0}) LIKE '%" + memberVO.getSearchText().replaceAll("-","") + "%'",info.hpNo));
}
}