在实际的开发过程中,我们使用jpa ,实长会有关联查询表的需求,比如通过部门id 关联查询部门表获取部门name,jpa关联查询会比较麻烦,这里可以通过java代码去组装我们想要的数据.
实现的方式有两种:
- 第一种方式可以将变动不大的部门存储到redis中,我们可以通过部门id直接查询缓存,这样不会很大的影响查询效率.
- 第二种方式可以将我要关联的部门表中的数据放到map 中 key 为部门id,value 为id对应的部门值.然后我在遍历集合去关联部门.
实现方式,这里我们用到了反射,通过反射获取对象的属性和属性值
直接上代码:
该类通过属性名称获取属性值
import java.lang.reflect.Field;
public class ReflectHelper {
public ReflectHelper() {
}
public static Field getFieldByFieldName(Object obj, String fieldName) {
//通过反射获取对象
Class superClass = obj.getClass();
while(superClass != Object.class) {
try {
//getDeclaredField(String name): 获取类特定的方法,name参数指定了属性的名称
return superClass.getDeclaredField(fieldName);
} catch (NoSuchFieldException var4) {
superClass = superClass.getSuperclass();
}
}
return null;
}
public static <T> T getValueByFieldName(Object obj, String fieldName) throws SecurityException, NoSuchFieldException, IllegalArgumentException, IllegalAccessException {
//获取对象属性
Field field = getFieldByFieldName(obj, fieldName);
T value = null;
if (field != null) {
// field.isAccessible() 为true表示这个变量可以访问
if (field.isAccessible()) {
//通过属性获取属性值
//get(Object obj) 返回指定对象obj上此 Field 表示的字段的值
value = field.get(obj);
} else {
// field.setAccessible(true)方法告诉安全机制,这个变量可以访问
field.setAccessible(true);
value = field.get(obj);
field.setAccessible(false);
}
}
return value;
}
}
将要关联的数据集合存储到map中
public class ObjectHelper {
public ObjectHelper () {
}
public static <T> Map<Object, T> ObjectByFieldName(Class<T> clz, String fieldName, List<T> dataList) throws Exception {
Map<Object, T> map = new HashMap();
if (dataList != null && dataList.size() != 0) {
Iterator var4 = dataList.iterator();
while(var4.hasNext()) {
T bean = (T) var4.next();
Object value = ReflectHelper.getValueByFieldName(bean, fieldName);
map.put(value, bean);
}
return map;
} else {
return map;
}
}
}