手机端小强原创文章,java小强个人博客站点
当前位置: 首页 >> 理论 >> JDBC 查询 Map转对象

JDBC 查询 Map转对象

38080 理论 | 2014-9-5

虽然项目中都夹杂了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);
}

同样通过对象的反射,获得属性名称和值。

推荐您阅读更多有关于“ java map 反射 对象 ”的文章

上一篇:传入Java对象 自动创建动态表 并录入数据 下一篇:程序员笑话集锦

猜你喜欢

发表评论:

个人资料
blogger

java小强
没有思考,人生的路会越走越难!

搜索
分类
最新微语
  • 不是本人但真实经历,如果你得了绝症抑或大病,能告诉的人两只手能数过来,而能一直陪床真正帮你的人,一只手就够了。也许你会说我亲戚多哥们多同学多云云,但真遇上的时候,你敢说吗?即使你说了会有人像你想的那样吗?不要尝试考验人性,人走茶凉之类的话都听过,但不遇到事我们未曾理解其中的道理。

    2018-11-07 11:05

  • 每个人的一生都是不同的,我们都需要负重前行。每一种生活都是不同的,我们都需要真实面对。所经历的,让我学会一件事,顺其自然。人,总有很多自己想要的,总有很多困难要面对,总有很多人要去爱,我们不断思考人生,却总是迷失自己。如今,我们最缺的不是金钱和时间,而是忘记了自己的初衷。

    2018-09-28 14:42

  • 车也学了,年也过了,生日也过了,村里的会也赶了,这次,是真的,年过去了。不过我没回京,也没有在家找工作,我在等什么吗?反正现在正合了我这个懒人的要求,不过,我歇不住,思考下人生。

    2018-03-20 00:11

  • 8月1日,我已离开奋斗多年的北京。不知道是暂时的离开,还是永久的离别,反正已经离职在家,告别每日上班,每天苦累的煎熬,过一段属于自己的生活。以前是专职工作,现在专职生活。

    2017-08-18 12:47

  • 又弄完一个项目,累成狗,但是感觉又进步不少,除了很多坑已经踩过,做起来也是轻车熟路。同时也认识到,程序不在于你多牛逼,而是在乎你的细节把控度,而细节的关注,是一个优秀程序员必须要注意的。另外,要相信自己,勇敢向前,没人生下来就是成功的,而且,成功的路,比成功本身更重要。

    2017-06-30 09:46

  • 更多»

最新文章
热门文章
随机文章