上一篇博客详细描述了SQL占位符的替换以及SQL的执行过程,对于查询语句返回的是一个List<CaseInsensitiveMap<String, Object>>,List里的泛型是一个CaseInsensitiveMap<String, Object>,这是一个Key不区分大小写的Map,那么是怎么把这个list转化为具体类型的呢?这篇将详细讲到。
就大部分业务而言,查询的返回值有两种,List和单个对象,不管对于List的泛型,还是单个对象,我们限定可能的类型有三种:Map、8大基本数据类型+String和Date、实体对象,这样基本满足大部分的业务了。话不多说,看代码:
public static Object createQueryResult(List<CaseInsensitiveMap<String, Object>> list, Method method)
throws Exception {
if (list.size() == 0) {
return null;
}
Type returnType = method.getGenericReturnType();// 返回类型
Class returnClass = method.getReturnType();
if (List.class.isAssignableFrom(returnClass)) {
if (returnType instanceof ParameterizedType) {
Type[] types = ((ParameterizedType) returnType).getActualTypeArguments();// 泛型类型列表
Class clazz = (Class) types[0];
if (Map.class.isAssignableFrom(clazz)) {
return list;
} else if (isPrimitive(clazz)) {
return createPrimitiveList(list, clazz);
} else {
return createEntityList(list, clazz);
}
}
return list;
} else {
if (list.size() > 1) {
throw new TeaOrmException("查询值过多");
}
if (isPrimitive(returnClass)) {
List result = createPrimitiveList(list, returnClass);
return result == null ? null : result.get(0);
} else if (Map.class.isAssignableFrom(returnClass)) {
return list.get(0);
} else {
List result = createEntityList(list, returnClass);
return result == null ? null : result.get(0);
}
}
}
对于实体对象属性的反射填充、基本类型数据的转化,请在码云中查看源代码:https://gitee.com/lxkm/teaframework/blob/master/TeaFramework/src/main/java/org/teaframework/orm/databind/util/QueryResultProcesser.java
项目地址:https://git.oschina.net/lxkm/teaframework
博客:https://blog.csdn.net/dong_lxkm