使用场景
1, listmap转成实体类,存入数据库
其中使用的下划线和驼峰命名互转方法https://blog.csdn.net/li740207611/article/details/87367383
/**
* List<Map>转成实体对象
* @param list map实体对象包含属性
* @param clazz 实体对象类型
* @param flag map的key是下划线(和数据库字段名称一致)命名则为true,key是驼峰命名则为false
* @return
*/
public static ArrayList map2Object(List<Map<String, Object>> list, Class<?> clazz, String id, boolean flag) {
ArrayList rs = new ArrayList();
if (ObjectUtils.isEmpty(list))
return rs;
list.forEach((key->{
key.put(HoldingConsts.COMPANY_ID_SQL, id);
key.put(HoldingConsts.STATUS_DELETE_SQL, HoldingConsts.STATUS_DELETE);
rs.add(map2Object(key, clazz, flag));
}));
return rs;
}
/**
* Map转成实体对象
* @param map map实体对象包含属性
* @param clazz 实体对象类型
* @param flag map的key是下划线(和数据库字段名称一致)命名则为true,key是驼峰命名则为false
* @return
*/
public static Object map2Object(Map<String, Object> map, Class<?> clazz, boolean flag) {
if (map == null) {
return null;
}
Object obj = null;
try {
obj = clazz.newInstance();
Field[] fields = obj.getClass().getDeclaredFields();
for (Field field : fields) {
int mod = field.getModifiers();
if (Modifier.isStatic(mod) || Modifier.isFinal(mod)) {
continue;
}
field.setAccessible(true);
if (flag)
field.set(obj, map.get(HumpToUnderline(field.getName())));
else
field.set(obj, map.get((field.getName())));
}
} catch (Exception e) {
e.printStackTrace();
}
return obj;
}
/**
* 实体对象转成Map
* @param obj 实体对象
* @return
*/
public static Map<String, Object> object2Map(Object obj) {
Map<String, Object> map = new HashMap<>();
if (obj == null) {
return map;
}
Class clazz = obj.getClass();
Field[] fields = clazz.getDeclaredFields();
try {
for (Field field : fields) {
field.setAccessible(true);
map.put(field.getName(), field.get(obj));
}
} catch (Exception e) {
e.printStackTrace();
}
return map;
}