对于前端传入的参数,或者我们查询出来的参数我们需要就参数进行参数的校验.
参数校验可以提高代码的健壮性,同时阻止不必要的查询,减少了和数据库之间的交互,一定程度上优化了数据库的性能.
我们一般的参数校验
if (searchMap.get("image") != null && !"".equals(searchMap.get("image")) {
throw new RuntimeException();
}
JDK1.7的方案
if (Objects.isNull(searchMap)) {
throw new RuntimeException();
}
JDK1.8方案
Optional optional = Optional.of(searchMap);
if (!optional.isPresent()) {
throw new RuntimeException();
}
或者使用注解
@NonNull Integer id
之前进行非空校验需要大量写if语句,通过三木运算符和criteria的特性(“如果为空还是criteria的本身”)
/**
* 构建查询对象
*
* @param searchMap
* @return
*/
private Example createExample(Map<String, Object> searchMap) {
Example example = new Example(Spec.class);
Example.Criteria criteria = example.createCriteria();
Optional optional = Optional.of(searchMap);
if (!optional.isPresent()) {
throw new RuntimeException();
}
String name = (String) searchMap.get("name");
String options = (String) searchMap.get("options");
String id = (String) searchMap.get("id");
String seq = (String) searchMap.get("seq");
String templateId = (String) searchMap.get("templateId");
criteria = StringUtils.isEmpty(name) ? criteria : criteria.andLike("name", "%" + searchMap.get("name") + "%");
criteria = StringUtils.isEmpty(options) ? criteria : criteria.andLike("options", "%" + searchMap.get("options") + "%");
criteria = StringUtils.isEmpty(id) ? criteria : criteria.andEqualTo("id");
criteria = StringUtils.isEmpty(seq) ? criteria : criteria.andEqualTo("seq");
criteria = StringUtils.isEmpty(templateId) ? criteria : criteria.andEqualTo("templateId");
return example;
}