我现在有一个要求,那就是在使用mybatis时(尤其是那些执行SQL的批处理),首先检查参数,如果参数为空或空,则返回,不继续,如果返回类型为List,例如。
List<User> getByIds(List<Long> idList)
如果返回类型为空,则返回空的ArrayList:
void batchInsert(List<User>)
返回NULL。 这样做的目的是避免这种情况,例如。
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中获取返回类型?
若要从ProceedingJoinPoint
获取方法返回类型/类,可以执行以下操作:
Signature signature = proceedingJoinPoint.getSignature();
Class returnType = ((MethodSignature) signature).getReturnType();