JDBC 查询 Map转对象

虽然项目中都夹杂了Hibernate的支持,但是团队开发中,很多人为了编写特殊查询的代码时都使用了JDBC进行查询。JDBC查询后返回的是一个List集合,List中组装的是Map,一个Map就是一个对应的对象。但是接口不能直接返回Map,都是返回的对象,以方便自己和其他人使用,为了转换这个Map,往往写这样的代码:

Java代码   收藏代码
  1. @SuppressWarnings("unchecked")  
  2. public static MS_Mont analyzeMapToMS_Mont(Map map){  
  3.     MS_Mont obj = new MS_Mont();  
  4.     if(null != map.get("montNo")) obj.setMontNo(Integer.parseInt(map.get("montNo").toString()));  
  5.     if(null != map.get("montName")) obj.setMontName(map.get("montName").toString());  
  6.     if(null != map.get("montType")) obj.setMontType(Integer.parseInt(map.get("montType").toString()));  
  7.     if(null != map.get("montLength")) obj.setMontLength(Integer.parseInt(map.get("montLength").toString()));  
  8.     if(null != map.get("montDesc")) obj.setMontDesc(map.get("montDesc").toString());  
  9.     if(null != map.get("bigType")) obj.setBigType(Integer.parseInt(map.get("bigType").toString()));  
  10.     if(null != map.get("bigTypeName")) obj.setBigTypeName(map.get("bigTypeName").toString());  
  11.     if(null != map.get("littleType")) obj.setLittleType(Integer.parseInt(map.get("littleType").toString()));  
  12.     if(null != map.get("littleTypeName")) obj.setLittleTypeName(map.get("littleTypeName").toString());  
  13.     if(null != map.get("insertTime")) obj.setInsertTime(map.get("insertTime").toString());  
  14.     if(null != map.get("updateTime")) obj.setUpdateTime(map.get("updateTime").toString());  
  15.     if(null != map.get("userNoRe")) obj.setUserNoRe(Integer.parseInt(map.get("userNoRe").toString()));  
  16.     if(null != map.get("userNoLast")) obj.setUserNoLast(Integer.parseInt(map.get("userNoLast").toString()));  
  17.     return obj;  
  18. }  

 

很麻烦,很多,很枯燥。
为了解决这个问题,我列出一个解决方法,写一个方法,传入要赋值的对象和Map,然后根据列的属性名称从Map中获得响应的值,然后赋值给这个对象的属性
例如,这里写了一个简单的查询:

 

Java代码   收藏代码
  1. public CM_Line getObjectBean(int lineNo) {  
  2.     try {  
  3.         String sql = "select * from cm_line where lineNo=?";  
  4.         Object[] obj = new Object[]{ lineNo };  
  5.         List rows = jdbcTemplate.queryForList( sql, obj );  
  6.         if(null != rows && rows.size() > 0) {  
  7.             CM_Line line = new CM_Line();  
  8.             return (CM_Line) line.analyzeMap((Map)rows.get(0));  
  9.         } else {  
  10.             return null;  
  11.         }  
  12.     } catch (Exception e) {  
  13.         logger.error(e);  
  14.     }  
  15.     return null;  
  16. }  

 

然后我们调用了他的analyzeMap方法,这个方法把当前对象当作要赋值的对象,然后调用公用方法进行组装:

Java代码   收藏代码
  1. public Object analyzeMap(Map<String, Object> para){  
  2.     Object obj = this;  
  3.     ObjectUtil.setValToObj(obj, para);  
  4.     return obj;  
  5. }  

 

公用方法:

Java代码   收藏代码
  1. public synchronized static void setValToObj(Object entityName, Map<String, Object> para){  
  2.     try {  
  3.         Class c = entityName.getClass();  
  4.         // 获得对象属性     
  5.         Field field[] = c.getDeclaredFields();  
  6.         for (Field f : field) {   
  7.             try {  
  8.                 PropertyDescriptor pd = new PropertyDescriptor(f.getName(), c);    
  9.                 Method writeMethod = pd.getWriteMethod();  
  10.                 if(!CommonCheck.isNullOrEmpty(para.get(f.getName())))  
  11.                     writeMethod.invoke(entityName, para.get(f.getName()));  
  12.             } catch (Exception e) {  
  13.             }  
  14.         }  
  15.     } catch (Exception e) {  
  16.     }  
  17. }  

 

下面就有人说了,那根据对象获得这个对象的Map怎么搞,这个之前已经写过了,不这里仍然把代码放一下:

Java代码   收藏代码
  1. /**     
  2.  * 返回一个对象的属性和属性值 
  3.  */       
  4. public synchronized static LinkedHashMap<String,String> getProAndValMap(Object entityName) {      
  5.     LinkedHashMap<String,String> map = new LinkedHashMap<String, String>();     
  6.     try {     
  7.         Class c = entityName.getClass();     
  8.         // 获得对象属性     
  9.         Field field[] = c.getDeclaredFields();        
  10.         for (Field f : field) {  
  11.             Object v = invokeMethod(entityName, f.getName(), null);     
  12.             if(null != v) map.put(f.getName(), v.toString());  
  13.             else  map.put(f.getName(), "");  
  14.         }     
  15.     } catch (Exception e) {     
  16.         map = null;     
  17.     }     
  18.     return map;     
  19. }  
  20. /** 
  21.  * 获得对象属性的值 
  22.  */  
  23. private synchronized static Object invokeMethod(Object owner, String methodName,  
  24.         Object[] args) throws Exception {  
  25.     Class ownerClass = owner.getClass();  
  26.     methodName = methodName.substring(01).toUpperCase() + methodName.substring(1);  
  27.     Method method = null;  
  28.     try {  
  29.         method = ownerClass.getMethod("get" + methodName);  
  30.     } catch (Exception e) {  
  31.     }  
  32.     return method.invoke(owner);  
  33. }  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值