JDBC查询Map转对象实现过程详解
虽然项目中都夹杂了Hibernate的支持,但是团队开发中,很多人为了编写特殊查询的代码时都使用了JDBC进行查询。JDBC查询后返回的是一个List集合,List中组装的是Map,一个Map就是一个对应的对象。但是接口不能直接返回Map,都是返回的对象,以方便自己和其他人使用,为了转换这个Map,往往写这样的代码:
@SuppressWarnings("unchecked")
publicstaticMS_MontanalyzeMapToMS_Mont(Mapmap){
MS_Montobj=newMS_Mont();
if(null!=map.get("montNo"))obj.setMontNo(Integer.parseInt(map.get("montNo").toString()));
if(null!=map.get("montName"))obj.setMontName(map.get("montName").toString());
if(null!=map.get("montType"))obj.setMontType(Integer.parseInt(map.get("montType").toString()));
if(null!=map.get("montLength"))obj.setMontLength(Integer.parseInt(map.get("montLength").toString()));
if(null!=map.get("montDesc"))obj.setMontDesc(map.get("montDesc").toString());
if(null!=map.get("bigType"))obj.setBigType(Integer.parseInt(map.get("bigType").toString()));
if(null!=map.get("bigTypeName"))obj.setBigTypeName(map.get("bigTypeName").toString());
if(null!=map.get("littleType"))obj.setLittleType(Integer.parseInt(map.get("littleType").toString()));
if(null!=map.get("littleTypeName"))obj.setLittleTypeName(map.get("littleTypeName").toString());
if(null!=map.get("insertTime"))obj.setInsertTime(map.get("insertTime").toString());
if(null!=map.get("updateTime"))obj.setUpdateTime(map.get("updateTime").toString());
if(null!=map.get("userNoRe"))obj.setUserNoRe(Integer.parseInt(map.get("userNoRe").toString()));
if(null!=map.get("userNoLast"))obj.setUserNoLast(Integer.parseInt(map.get("userNoLast").toString()));
returnobj;
}
很麻烦,很多,很枯燥。
为了解决这个问题,我列出一个解决方法,写一个方法,传入要赋值的对象和Map,然后根据列的属性名称从Map中获得响应的值,然后赋值给这个对象的属性。
例如,这里写了一个简单的查询:
publicCM_LinegetObjectBean(intlineNo){
try{
Stringsql="select*fromcm_linewherelineNo=?";
Object[]obj=newObject[]{lineNo};
Listrows=jdbcTemplate.queryForList(sql,obj);
if(null!=rows&&rows.size()>0){
CM_Lineline=newCM_Line();
return(CM_Line)line.analyzeMap((Map)rows.get(0));
}else{
returnnull;
}
}catch(Exceptione){
logger.error(e);
}
returnnull;
}
然后我们调用了他的analyzeMap方法,这个方法把当前对象当作要赋值的对象,然后调用公用方法进行组装:
publicObjectanalyzeMap(Mappara){ Objectobj=this; ObjectUtil.setValToObj(obj,para); returnobj; }
公用方法:
publicsynchronizedstaticvoidsetValToObj(ObjectentityName,Mappara){ try{ Classc=entityName.getClass(); //获得对象属性 Fieldfield[]=c.getDeclaredFields(); for(Fieldf:field){ try{ PropertyDescriptorpd=newPropertyDescriptor(f.getName(),c); MethodwriteMethod=pd.getWriteMethod(); if(!CommonCheck.isNullOrEmpty(para.get(f.getName()))) writeMethod.invoke(entityName,para.get(f.getName())); }catch(Exceptione){ } } }catch(Exceptione){ } }
下面就有人说了,那根据对象获得这个对象的Map怎么搞,这个之前已经写过了,不这里仍然把代码放一下:
/** *返回一个对象的属性和属性值 */ publicsynchronizedstaticLinkedHashMapgetProAndValMap(ObjectentityName){ LinkedHashMap map=newLinkedHashMap (); try{ Classc=entityName.getClass(); //获得对象属性 Fieldfield[]=c.getDeclaredFields(); for(Fieldf:field){ Objectv=invokeMethod(entityName,f.getName(),null); if(null!=v)map.put(f.getName(),v.toString()); elsemap.put(f.getName(),""); } }catch(Exceptione){ map=null; } returnmap; } /** *获得对象属性的值 */ privatesynchronizedstaticObjectinvokeMethod(Objectowner,StringmethodName, Object[]args)throwsException{ ClassownerClass=owner.getClass(); methodName=methodName.substring(0,1).toUpperCase()+methodName.substring(1); Methodmethod=null; try{ method=ownerClass.getMethod("get"+methodName); }catch(Exceptione){ } returnmethod.invoke(owner); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。