JDBC查詢Map轉(zhuǎn)對(duì)象實(shí)現(xiàn)過程詳解
雖然項(xiàng)目中都夾雜了Hibernate的支持,但是團(tuán)隊(duì)開發(fā)中,很多人為了編寫特殊查詢的代碼時(shí)都使用了JDBC進(jìn)行查詢。JDBC查詢后返回的是一個(gè)List集合,List中組裝的是Map,一個(gè)Map就是一個(gè)對(duì)應(yīng)的對(duì)象。但是接口不能直接返回Map,都是返回的對(duì)象,以方便自己和其他人使用,為了轉(zhuǎn)換這個(gè)Map,往往寫這樣的代碼:
@SuppressWarnings("unchecked") public static MS_Mont analyzeMapToMS_Mont(Map map){ MS_Mont obj = new MS_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())); return obj; }
很麻煩,很多,很枯燥。
為了解決這個(gè)問題,我列出一個(gè)解決方法,寫一個(gè)方法,傳入要賦值的對(duì)象和Map,然后根據(jù)列的屬性名稱從Map中獲得響應(yīng)的值,然后賦值給這個(gè)對(duì)象的屬性。
例如,這里寫了一個(gè)簡(jiǎn)單的查詢:
public CM_Line getObjectBean(int lineNo) { try { String sql = "select * from cm_line where lineNo=?"; Object[] obj = new Object[]{ lineNo }; List rows = jdbcTemplate.queryForList( sql, obj ); if(null != rows && rows.size() > 0) { CM_Line line = new CM_Line(); return (CM_Line) line.analyzeMap((Map)rows.get(0)); } else { return null; } } catch (Exception e) { logger.error(e); } return null; }
然后我們調(diào)用了他的analyzeMap方法,這個(gè)方法把當(dāng)前對(duì)象當(dāng)作要賦值的對(duì)象,然后調(diào)用公用方法進(jìn)行組裝:
public Object analyzeMap(Map<String, Object> para){ Object obj = this; ObjectUtil.setValToObj(obj, para); return obj; }
公用方法:
public synchronized static void setValToObj(Object entityName, Map<String, Object> para){ try { Class c = entityName.getClass(); // 獲得對(duì)象屬性 Field field[] = c.getDeclaredFields(); for (Field f : field) { try { PropertyDescriptor pd = new PropertyDescriptor(f.getName(), c); Method writeMethod = pd.getWriteMethod(); if(!CommonCheck.isNullOrEmpty(para.get(f.getName()))) writeMethod.invoke(entityName, para.get(f.getName())); } catch (Exception e) { } } } catch (Exception e) { } }
下面就有人說(shuō)了,那根據(jù)對(duì)象獲得這個(gè)對(duì)象的Map怎么搞,這個(gè)之前已經(jīng)寫過了,不這里仍然把代碼放一下:
/** * 返回一個(gè)對(duì)象的屬性和屬性值 */ public synchronized static LinkedHashMap<String,String> getProAndValMap(Object entityName) { LinkedHashMap<String,String> map = new LinkedHashMap<String, String>(); try { Class c = entityName.getClass(); // 獲得對(duì)象屬性 Field field[] = c.getDeclaredFields(); for (Field f : field) { Object v = invokeMethod(entityName, f.getName(), null); if(null != v) map.put(f.getName(), v.toString()); else map.put(f.getName(), ""); } } catch (Exception e) { map = null; } return map; } /** * 獲得對(duì)象屬性的值 */ private synchronized static Object invokeMethod(Object owner, String methodName, Object[] args) throws Exception { Class ownerClass = owner.getClass(); methodName = methodName.substring(0, 1).toUpperCase() + methodName.substring(1); Method method = null; try { method = ownerClass.getMethod("get" + methodName); } catch (Exception e) { } return method.invoke(owner); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解Java的JDBC中Statement與PreparedStatement對(duì)象
- JDBC之PreparedStatement類中預(yù)編譯的綜合應(yīng)用解析
- JDBCTM 指南:入門6-PreparedStatement
- Oracle JDBC連接BUG解決方案
- jdbc實(shí)現(xiàn)寵物商店管理系統(tǒng)
- Jmeter基于JDBC請(qǐng)求實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)測(cè)試
- Java如果通過jdbc操作連接oracle數(shù)據(jù)庫(kù)
- JDBC PreparedStatement Like參數(shù)報(bào)錯(cuò)解決方案
相關(guān)文章
MyBatis查詢數(shù)據(jù)庫(kù)語(yǔ)句總結(jié)
MyBatis是一種持久化框架,可以與許多不同類型的關(guān)系型數(shù)據(jù)庫(kù)連接,下面這篇文章主要給大家介紹了關(guān)于MyBatis查詢數(shù)據(jù)庫(kù)語(yǔ)句的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06SpringBoot整合Mybatis-plus實(shí)現(xiàn)多級(jí)評(píng)論功能
本文介紹了如何使用SpringBoot整合Mybatis-plus實(shí)現(xiàn)多級(jí)評(píng)論功能,同時(shí)提供了數(shù)據(jù)庫(kù)的設(shè)計(jì)和詳細(xì)的后端代碼,前端界面使用的Vue2,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-05-05Java中Cookie和Session詳解及區(qū)別總結(jié)
這篇文章主要介紹了Java中Cookie和Session詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-06-06解決spring boot創(chuàng)建項(xiàng)目遇到配置的問題
這篇文章主要介紹了解決spring boot創(chuàng)建項(xiàng)目遇到配置的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09為什么在foreach循環(huán)中JAVA集合不能添加或刪除元素
今天給大家?guī)?lái)的文章是關(guān)于Java的相關(guān)知識(shí),文章圍繞著為什么在foreach循環(huán)中JAVA集合不能添加或刪除元素展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06java?線程池狀態(tài)及狀態(tài)轉(zhuǎn)換
這篇文章主要介紹了java?線程池狀態(tài)及狀態(tài)轉(zhuǎn)換,Java里線程池的狀態(tài)和線程的狀態(tài)是完全不同的,具體有幾種狀態(tài)和哪些不同點(diǎn),下面文章詳細(xì)介紹,需要的小伙伴可以參考一下2022-05-05