我的漫漫程序之旅

专注于JavaWeb开发
随笔 - 39, 文章 - 310, 评论 - 411, 引用 - 0
数据加载中……

Spring jdbc 对象Mapper的简单封装

一般查询实体的时候,都需要这么使用:
/**
     * 根据id查询
     * 
     * 
@return
     
*/

    
public Emp queryEmpById(Integer id)
    
{
        String sql 
= "select * from emp where empno = ?";
        ParameterizedRowMapper
<Emp> mapper = new ParameterizedRowMapper<Emp>()
        
{

            
public Emp mapRow(ResultSet rs, int rowNum) throws SQLException
            
{
                Emp emp 
= new Emp();
                System.out.println(
"row:" + rowNum);
                emp.setEmpno(rs.getInt(
"empno"));
                emp.setEname(rs.getString(
"ename"));
                
return emp;
            }

        }
;

        
return this.getSimpleJdbcTemplate().queryForObject(sql, mapper, id);
    }

能不能像Hibernate那样自动set这些值呢,用反射可以实现.

package orm;

import java.lang.reflect.Field;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.springframework.jdbc.core.simple.ParameterizedRowMapper;

/**
 * 通用的Object包装类(类型问题,依然是个瓶颈,如果有好的解决方案请pm我)
 * 
 * 功能:查询对象类型或对象集合时的通用包装类
 * 
 * 
@author zdw
 * 
 
*/

@SuppressWarnings(
"unchecked")
public class ObjectMapper implements ParameterizedRowMapper
{
    
private Class clazz;

    
public ObjectMapper(Class clazz)
    
{
        
this.clazz = clazz;
    }


    
/**
     * 重写mapRow方法
     
*/

    @Override
    
public Object mapRow(ResultSet rs, int rowNum) throws SQLException
    
{
        
try
        
{
            Object obj 
= clazz.newInstance();
            Field fields[] 
= obj.getClass().getDeclaredFields();
            
for (int i = 0; i < fields.length; i++)
            
{
                Field field 
= fields[i];
                
// 暴力访问
                field.setAccessible(true);
                
this.typeMapper(field, obj, rs);
                
// 恢复默认
                field.setAccessible(false);
            }

            
return obj;
        }

        
catch (Exception e)
        
{
            e.printStackTrace();
        }

        
return null;
    }


    
/**
     * 数据类型包装器
     * 
     * 
@param field
     *            目标属性
     * 
@param obj
     *            目标对象
     * 
@param rs
     *            结果集
     * 
@throws Exception
     
*/

    
private void typeMapper(Field field, Object obj, ResultSet rs)
            
throws Exception
    
{
        String type 
= field.getType().getName();
        
if (type.equals("java.lang.String"))
        
{
            field.set(obj, rs.getString(field.getName()));
        }

        
else if (type.equals("int"|| type.equals("java.lang.Integer"))
        
{
            field.set(obj, rs.getInt(field.getName()));
        }

        
else if (type.equals("long"|| type.equals("java.lang.Long"))
        
{
            field.set(obj, rs.getLong(field.getName()));
        }

        
else if (type.equals("boolean"|| type.equals("java.lang.Boolean"))
        
{
            field.set(obj, rs.getBoolean(field.getName()));
        }

        
else if (type.equals("java.util.Date"))
        
{
            field.set(obj, rs.getDate(field.getName()));
        }

    }

}



dao:
/**
     * 查询操作 (自动setEmp类型所有值)
     * 
     * 
@return
     
*/

    
public List queryList()
    
{
        
return this.getJdbcTemplate().query("select * from emp",
                
new ObjectMapper(Emp.class));
    }

单个查询:
public Emp queryEmpById2(Integer id)
    
{
        String sql 
= "select * from emp where empno = ?";
        ObjectMapper om 
= new ObjectMapper(Emp.class);
        
return (Emp) this.getSimpleJdbcTemplate().queryForObject(sql, om, id);
    }
测试通过:
7369
7499
7521
7566
7654
7698
7782
7788
7839
7844

上面是我的一个简单封装,在Spring2.5中及以后版本,已经提供了便捷方法:
/**
     * 查询操作 (自动setEmp类型所有值)
     * 
     * 
@return
     
*/

    
public List queryList()
    
{
        
return this.getSimpleJdbcTemplate().query(   
                
"SELECT * from emp",   
                ParameterizedBeanPropertyRowMapper.newInstance(Emp.
class));  
    }

    
    
/**
     * 根据id查询
     * 
     * 
@return
     
*/

    
public Emp queryById(Integer id)
    
{
        
return this.getSimpleJdbcTemplate().queryForObject(   
                
"SELECT * from emp where id = ?",   
                ParameterizedBeanPropertyRowMapper.newInstance(Emp.
class),7369);  
    }

这样就简单多了,也是用反射实现的.


posted on 2009-03-30 16:28 々上善若水々 阅读(4344) 评论(1)  编辑  收藏

评论

# re: Spring jdbc 对象Mapper的简单封装  回复  更多评论   

楼上说话请自重。我这是自己写的。
2009-04-13 08:34 | 々上善若水々

只有注册用户登录后才能发表评论。


网站导航: