虽然项目中都夹杂了Hibernate的支持,但是团队开发中,很多人为了编写特殊查询的代码时都使用了JDBC进行查询。JDBC查询后返回的是一个List集合,List中组装的是Map,一个Map就是一个对应的对象。但是接口不能直接返回Map,都是返回的对象,以方便自己和其他人使用,为了转换这个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; }
很麻烦,很多,很枯燥。
为了解决这个问题,我列出一个解决方法,写一个方法,传入要赋值的对象和Map,然后根据列的属性名称从Map中获得响应的值,然后赋值给这个对象的属性。
例如,这里写了一个简单的查询:
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; }
然后我们调用了他的analyzeMap方法,这个方法把当前对象当作要赋值的对象,然后调用公用方法进行组装:
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(); // 获得对象属性 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) { } }
下面就有人说了,那根据对象获得这个对象的Map怎么搞,这个之前已经写过了,不这里仍然把代码放一下:
/** * 返回一个对象的属性和属性值 */ public synchronized static LinkedHashMap<String,String> getProAndValMap(Object entityName) { LinkedHashMap<String,String> map = new LinkedHashMap<String, String>(); try { Class c = entityName.getClass(); // 获得对象属性 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; } /** * 获得对象属性的值 */ 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); }
请您到ITEYE网站看原创,谢谢!
http://cuisuqiang.iteye.com/ !
自建博客地址:http://www.javacui.com/ ,内容与ITEYE同步!
相关推荐
包括了jdbc的增删改查的方法,其中包含查询返回包括实体和Map结果,支持更新对象和保存对象的操作。
一般使用springjdbc、hibernate的sql查询,库获取到的数据都是List<Map, Object>>结果集,如果我们要转化为JavaBean,则需要做一系列的map.get(),然后obj.set()。 此工程中就是解决List<Map, Object>>转化为...
Java-JDBC【之】数据类型、封装JDBCUtil、封装通用增删改、ResultSet与ResultSetMetaData、查询结果集映射Map与ListMap 1.数据类型 2.封装通用增删改 2.1.封装JDBCUtil 2.2.封装Dao通用增删改 2.3.测试 3.ResultSet...
Java JDBC封装类,带增删改查例子,支持oracle,MySql,hsqldb 等,支持事务,返回数据格式 支持二维数组,MAP格式,以及javabean对象。有利于初学者DbDemo.java为demo,Connect为jdbc封装类,可以作为项目共通类使用。
15.2 将结果集封装为对象 91 15.2.1 user表POJO的编写 91 15.2.2 Bean结果集的封装 92 15.3 将结果集封装为List 94 15.4 策略模式的应用 96 15.4.1 Map结果集策略模式应用 96 15.4.2 Bean结果集策略模式应用 97 ...
简单易用的数据库封装操作,包含数据库连接池的基本实现,数据库连接可重用,所有的操作都脱离源生JDBC操作,开发人员只需要熟悉Java...(注意:作为参数用完的集合和Map注意调用.clear()方法,保证对象正常回收gc。)
ORM工具主要功能分两部分,一是将spring jdbc查询返回Map转换成对应的实体对象,方便上层结构使用。二是自动生成增/删/改/查以及分页查询sql语句,使用了此工具后基础的语句就不必在费尽心思copy 改了。绝对会...
Java JDBC封装类升级版,带增删改查例子,支持oracle,MySql,hsqldb 等,支持事务,返回数据格式 支持二维数组,MAP格式,以及javabean对象。有利于初学者DbDemo.java为demo,Connect为jdbc封装类,可以作为项目共通类...
2.1 直接通过JDBC API来持久化实体域对象 2.2 ORM简介 2.2.1 对象-关系映射的概念 2.2.2 ORM中间件的基本使用方法 2.2.3 常用的ORM中间件 2.3 实体域对象的其他持久化模式 2.3.1 主动域对象模式 ...
Map,LikeItem> condition = new HashMap(); /*condition.put("user_sex", new LikeItem("男")); condition.put("user_name", new LikeItem("张三", LikeModle.LIKE));*/ // 测试升级模糊查询方法 System.out....
2.1 直接通过JDBC API来持久化实体域对象 2.2 ORM简介 2.2.1 对象-关系映射的概念 2.2.2 ORM中间件的基本使用方法 2.2.3 常用的ORM中间件 2.3 实体域对象的其他持久化模式 2.3.1 主动域对象模式 ...
DBUtils封装了对JDBC的操作 简化了JDBC操作 可以少写代码 org apache commons dbutils DbUtils 关闭链接等操作 QueryRunner 进行查询的操作 org apache commons dbutils handlers ArrayHandler :将ResultSet中第一...
2.1 直接通过JDBC API来持久化实体域对象 2.2 ORM简介 2.2.1 对象-关系映射的概念 2.2.2 ORM中间件的基本使用方法 2.2.3 常用的ORM中间件 2.3 实体域对象的其他持久化模式 2.3.1 主动域对象模式 ...
2.1 直接通过JDBC API来持久化实体域对象 2.2 ORM简介 2.2.1 对象-关系映射的概念 2.2.2 ORM中间件的基本使用方法 2.2.3 常用的ORM中间件 2.3 实体域对象的其他持久化模式 2.3.1 主动域对象模式 ...
Java面向对象程序设计笔记: 目录----非原创,上课的时候老师给的资料哦 第一章 Java 前凑 3 1. Java前凑 3 Java产生的目的 3 Java的诞生的历史 3 2.Java语言的特点 3 ...第九章JDBC编 32 第十章GUI编程 32
查询所有的内容,封装为对象用:template.query(sql, new BeanPropertyRowMapper<对象>(对象.class)); 查询需要使用聚合函数的内容,如:select count(id)from account用:template.queryForObject(sql)
Spring中使用jdbc模板来查询数据,查询出来的是list中放有map,通过mapper类来讲list中的map转为对象存到list中
可以将sql语句传给Sql对象来查询数据表,也可以直接使用String类型的sql语句: // execute query val result = Sql ( " select * from customer " ).query import ...
3、若无记录,则返回零长度Map对象 4、零长度字符串存入数据库中将保存为null 5、返回值与标准Java库方法返回值一致 6、若仅仅是调用标准库中的方法,则方法签名与被调用方法签名一致 7、遵守驼峰式命名规则 第...