我现在有一个需求,就是在使用mybatis时(尤其是批量执行sql的时候),首先检查参数,如果参数为null或空,则直接返回,不继续,如果返回类型是List,例如。
List<User> getByIds(List<Long> idList)
如果返回类型为 void,则返回空 ArrayList:
void batchInsert(List<User>)
返回空值。
目的是避免这种情况,例如。
select * from user where id in ()
insert into user(name,email) values ()
但从 joinPoint 我无法获取返回类型,只能获取参数。
Object[] args = joinPoint.getArgs();
if(args!=null&&args.length=1){
if(args[0] instanceof List){
if(((List) obj).isEmpty()){
if(returnType.equals("java.util.List"))
return new ArrayList();
else if(returnType.equals("void"))
return null;
}
}
return joinPoint.proceed();
那么如何获取 aop:around 中的返回类型呢?
从a获取方法返回类型/类ProceedingJoinPoint
你可以这样做:
Signature signature = proceedingJoinPoint.getSignature();
Class returnType = ((MethodSignature) signature).getReturnType();
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)