-
Java 通过属性名称读取或者设置实体的属性值
原因
项目实战中有这个需求,数据库中配置对应的实体和属性名称,在代码中通过属性名称获取实体的对应的属性值。
解决方案
工具类,下面这个工具是辅助获取属性值
import com.alibaba.fastjson.JSONObject; public class StringUtil { /** * 对象转成json字符串 * * @param obj * @return */ public static String toJson(Object obj) { return JSONObject.toJSONString(obj); } /** * 对象转成JSONObject * * @param obj * @return */ public static JSONObject toJsonObject(Object obj) { return JSONObject.parseObject(toJson(obj)); } /** * 获取对象的指定字段的值 * * @param obj * @param propName * @return */ public static String getPropValue(Object obj, String propName){ String propValue = StringConst.EMPTY; try { if(null!=obj) { JSONObject jsonObject = toJsonObject(obj); if (!StringUtil.isEmptyOrNull(propName)) { propValue = jsonObject.getString(propName); } } } catch (Exception e) { log.error(e.getMessage()); } return propValue; } }
下面这个是提供给接口使用的读取设置属性值的工具类
/** * @Description: 读取指定实体类的指定属性字段值 */ public class TableUtil { /** * 通过propName传进来的值,判断从哪个表取值 * * @param obj 当前使用的实体 * @param propName 表名.列名;表名.列名 * @return */ public String getValue(Object obj, String propName) { StringBuilder stringBuilder = new StringBuilder(StringConst.EMPTY); List<String> props = Arrays.stream(StringUtil.ifEmptyOrNullReturnValue(propName).split(";")).collect(Collectors.toList()); for (String prop : props) { String temp = null; List<String> tableNames = Arrays.stream(StringUtil.ifEmptyOrNullReturnValue(prop).split("\\.")).collect(Collectors.toList()); // 表名.列名,数据库中配置的是实体名称+属性名称 if (tableNames.size() > 1) { // 表名 String tableName = tableNames.get(0); // 列名 String colName = tableNames.get(1); if ("special".equalsIgnoreCase(tableName)) {// 如果需要对一些实体进行特殊处理,比如说某些实体从缓存读取,或者某个实体中的属性值需要特殊处理,就可以在下面增加特殊处理逻辑 temp = StringUtil.getPropValue(specialModel, colName); } else { temp = StringUtil.getPropValue(obj, colName); } } else if (tableNames.size() > 0) {// 数据库中只配置了属性名称,说明只有某个实体才会用到该记录,到时候获取属性值的时候记得把obj传进来 // 列名 String colName = tableNames.get(0); if (colName.contains("?")) {//特殊处理数据库中配置的三目运算符 // 如:sheathProtector=="有"?0:1 String tempColName = colName.split("\\?")[0].split("==")[0].trim(); String tempColValue = colName.split("\\?")[0].split("==")[1].replace("\"", "").replace("'", "").trim(); String tempValue = StringUtil.getPropValue(obj, tempColName); if (tempValue.equals(tempColValue)) { temp = colName.split("\\?")[1].split(":")[0]; } else { temp = colName.split("\\?")[1].split(":")[1]; } } else { temp = StringUtil.getPropValue(obj, colName); } } } String result = stringBuilder.toString(); return result; } /** * 为实体赋值 * * @param obj * @param propName * @param value * @return */ public Object setValue(Object obj, String propName, String value) { try { Field f = obj.getClass().getDeclaredField(propName); f.setAccessible(true); f.set(obj, value); } catch (Exception e) { return null; } return obj; } }
使用
TableUtil tableUtil; public void test(){ Person p = new Person(); String age = tableUtile.getValue(p,"age");// 读取属性值 tableUtil.setValue(p,"age",23);// 设置属性值 }
出处:https://www.cnblogs.com/dawenyang/p/15261080.html
最新更新
python爬虫及其可视化
使用python爬取豆瓣电影短评评论内容
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比