这是在实际开发项目中遇到的一个问题。从数据库查询返回的 List< Map< String, Object>> 的集合。并且返回的列名是中文的,项目也没有使用mybatis 直接使用的jdbcTemplate. 并且字段还超级多,这样将数据转换的时候如果一个一个的注入就会让代码臭长臭长的,所以才有了动态注入。我这里我整个思路都贴出来。
实例类Entry
========
我们先建一个entry类。用于对象存储。我这里 创建一个BaseDateBean 的类
@Setter
@Getter
public class BaseDateBean {
private String startTime;
private String operator;
private String code;
private String testNumber;
private String iphoneCardCode;
private String sampleNumber;
private String sampleTime;
private String callNumber;
private String callStatus;
private String downInstantaneousSpeedCard;
private String upInstantaneousSpeedCard;
private String ssid;
private String bssid;
private String encryptType;
private String intranetIp;
private String externalIp;
private String rssi;
private String WIFIFrequency;
private String WIFIChannel;
private String baiduLongitude;
private String baiduLatitude;
private String originalLongitude;
private String originalLatitude;
private String positioningPrecision;
private String positioningType;
private String businessType;
private String networkType;
private String speedType;
private String tac;
private String eci;
private String mnc;
private String mcc;
private String rsrq;
private String earfcnDl;
private String earfcnUl;
private String frequencyDl;
private String band;
private String sinr;
private String cdmaRxlev;
private String evdoRxlev;
private String earfcn;
private String psc;
private String uarfcn;
private String rscp;
private String rsrp;
private String imsi;
private String imei;
private String lac;
private String ci;
private String signalStrength;
private String snr;
private String pci;
private String nid;
private String bid;
private String sid;
private String cdmaDbm;
private String cdmaEcio;
private String evdoDbm;
private String evdoEcio;
private String evdoSnr;
private String arfcn;
private String frequencyUl;
private String bsic;
private String rxlev;
private String averageSpeed;
private String updatedLongitude;
private String updatedLatitude;
private String averageUpstreamRate;
private String averageDownstreamRate;
}
可以看到在实际项目中属性还是很多的,我这个还只是初版的,所以如果一个一个的set注入就很low了。
创建map映射
=======
在创建好实体类后,还得创建一个静态的map 集合,将数据库的列名和我们实体类的属性名做一个一一对应。这里创建的这个map 集合是我个人愚见。没有想到更好的办法就先这样处理的。我们创建一个BaseDataMap类
public class BaseDataMap{
private BaseDataMap(){}
public static final Map<String,String> cnEnMap=new HashMap<>();
static{
cnEnMap.put(“测试开始时间”,“startTime”);
cnEnMap.put(“运营商”,“operator”);
cnEnMap.put(“编号”,“code”);
cnEnMap.put(“测试编号”,“testNumber”);
cnEnMap.put(“手机卡编号”,“iphoneCardCode”);
cnEnMap.put(“采样编号”,“sampleNumber”);
cnEnMap.put(“采样时间”,“sampleTime”);
cnEnMap.put(“呼叫编号”,“callNumber”);
cnEnMap.put(“呼叫状态”,“callStatus”);
cnEnMap.put(“下行瞬时速度”,“downInstantaneousSpeedCard”);
cnEnMap.put(“上行瞬时速度”,“upInstantaneousSpeedCard”);
cnEnMap.put(“SSID”,“ssid”);
cnEnMap.put(“BSSID”,“bssid”);
cnEnMap.put(“加密类型”,“encryptType”);
cnEnMap.put(“内网IP”,“intranetIp”);
cnEnMap.put(“外网IP”,“externalIp”);
cnEnMap.put(“RSSI”,“rssi”);
cnEnMap.put(“WIFI频率”,“WIFIFrequency”);
cnEnMap.put(“WIFI信道”,“WIFIChannel”);
cnEnMap.put(“百度经度”,“baiduLongitude”);
cnEnMap.put(“百度纬度”,“baiduLatitude”);
cnEnMap.put(“原始经度”,“originalLongitude”);
cnEnMap.put(“原始纬度”,“originalLatitude”);
cnEnMap.put(“定位精度”,“positioningPrecision”);
cnEnMap.put(“定位类型”,“positioningType”);
cnEnMap.put(“数据业务类型”,“businessType”);
cnEnMap.put(“网络类型”,“networkType”);
cnEnMap.put(“速度类型”,“speedType”);
cnEnMap.put(“TAC”,“tac”);
cnEnMap.put(“ECI”,“eci”);
cnEnMap.put(“MNC”,“mnc”);
cnEnMap.put(“MCC”,“mcc”);
cnEnMap.put(“RSRQ”,“rsrq”);
cnEnMap.put(“EARFCN DL”,“earfcnDl”);
cnEnMap.put(“EARFCN UL”,“earfcnUl”);
cnEnMap.put(“FREQUENCY DL”,“frequencyDl”);
cnEnMap.put(“BAND”,“band”);
cnEnMap.put(“SINR”,“sinr”);
cnEnMap.put(“CDMA RXLEV”,“cdmaRxlev”);
cnEnMap.put(“EVDO RXLEV”,“evdoRxlev”);
cnEnMap.put(“EARFCN”,“earfcn”);
cnEnMap.put(“PSC”,“psc”);
cnEnMap.put(“UARFCN”,“uarfcn”);
cnEnMap.put(“RSCP”,“rscp”);
cnEnMap.put(“RSRP”,“rsrp”);
cnEnMap.put(“IMSI”,“imsi”);
cnEnMap.put(“IMEI”,“imei”);
cnEnMap.put(“LAC”,“lac”);
cnEnMap.put(“CI”,“ci”);
cnEnMap.put(“信号强度”,“signalStrength”);
cnEnMap.put(“SNR”,“snr”);
cnEnMap.put(“PCI”,“pci”);
cnEnMap.put(“NID”,“nid”);
cnEnMap.put(“BID”,“bid”);
cnEnMap.put(“SID”,“sid”);
cnEnMap.put(“CDMA DBM”,“cdmaDbm”);
cnEnMap.put(“CDMA ECIO”,“cdmaEcio”);
cnEnMap.put(“EVDO DBM”,“evdoDbm”);
cnEnMap.put(“EVDO ECIO”,“evdoEcio”);
cnEnMap.put(“EVDO SNR”,“evdoSnr”);
cnEnMap.put(“ARFCN”,“arfcn”);
cnEnMap.put(“FREQUENCY UL”,“frequencyUl”);
cnEnMap.put(“BSIC”,“bsic”);
cnEnMap.put(“RXLEV”,“rxlev”);
cnEnMap.put(“速率”,“averageSpeed”);
cnEnMap.put(“更正后经度”,“updatedLongitude”);
cnEnMap.put(“更正后纬度”,“updatedLatitude”);
cnEnMap.put(“上行平均速率”,“averageUpstreamRate”);
cnEnMap.put(“下行平均速率”,“averageDownstreamRate”);
}
}
可以看到就是一个动态的map。
映射类
===
接下来就是核心代码啦。我们创建一个ReflectHelper类
@Slf4j
public class ReflectHelper {
private Class cls;
/**
- 传过来的对象
*/
private Object obj;
private Hashtable<String, Method> getMethods = null;
private Hashtable<String, Method> setMethods = null;
public ReflectHelper(Object o) {
obj = o;
initMethods();
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
Ending
Tip:由于文章篇幅有限制,下面还有20个关于MySQL的问题,我都复盘整理成一份pdf文档了,后面的内容我就把剩下的问题的目录展示给大家看一下
如果觉得有帮助不妨【转发+点赞+关注】支持我,后续会为大家带来更多的技术类文章以及学习类文章!(阿里对MySQL底层实现以及索引实现问的很多)
吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
妨【转发+点赞+关注】支持我,后续会为大家带来更多的技术类文章以及学习类文章!**(阿里对MySQL底层实现以及索引实现问的很多)
[外链图片转存中…(img-poaItv4I-1713632298999)]
[外链图片转存中…(img-PRxx50w9-1713632298999)]
吃透后这份pdf,你同样可以跟面试官侃侃而谈MySQL。其实像阿里p7岗位的需求也没那么难(但也不简单),扎实的Java基础+无短板知识面+对某几个开源技术有深度学习+阅读过源码+算法刷题,这一套下来p7岗差不多没什么问题,还是希望大家都能拿到高薪offer吧。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!