我的万能dao 设计源码,请大家多多指教!

本文介绍了一种基于Spring和Hibernate的通用DAO设计方法,并详细展示了IBaseDao接口及其实现类BaseDaoImpl的具体功能,包括增删改查、分页查询等操作。
首先,先看下类图:(在这篇文章已经发过了[url]http://lym6520.iteye.com/admin/blogs/421504[/url])
我补充了Query层来存放hql或sql,如下:
[img]http://lym6520.iteye.com/upload/attachment/123871/35fdf67e-ce9d-3a65-a1ae-0cc6de00ac48.png[/img]

现在我们来看下IBaseDao.java文件:


package lym.dao.base.hibernate;

import java.io.Serializable;
import java.util.Collection;
import java.util.List;

import lym.dao.obj.AbstractHandleObj;

import org.hibernate.type.Type;

/**
* 基础Dao接口,定义通用的操作
* @author 林元脉
* @version v1.1 2009/07/17
*
*/
public interface IBaseDao {

/**
* 对于返回列表的方法,通过调用我来实现返回记录数的控制,
* 设置返回记录数,若top为0不设置
*/
public void setMaxResults(int top);

/**
* 保存AbstractHandleObj实体
* @param hobj 继承AbstractHandleObj抽象类的实体
* @return Serializable 主键
*/
public Serializable save(AbstractHandleObj hobj);

/**
* 更新AbstractHandleObj实体
* @param hobj 继承AbstractHandleObj抽象类的实体
*/
public void update(AbstractHandleObj hobj);

/**
* 保存或更新AbstractHandleObj实体
* @param hobj 继承AbstractHandleObj抽象类的实体
*/
public void saveOrUpdate(AbstractHandleObj hobj);

/**
* 保存或跟新实体集合Collection<AbstractHandleObj>
* 若实体已经存(根据主键判断)在则更新实体,则保存实体
* @param hobjList 继承AbstractHandleObj抽象类的实体集合
*/
public void saveOrUpdateAll(Collection<AbstractHandleObj> hobjList);

/**
* 删除AbstractHandleObj实体
* @param hobj 继承AbstractHandleObj抽象类的实体
*/
public void delete(AbstractHandleObj hobj);

/**
* 删除Collection<AbstractHandleObj>集合实体
* @param hobjList 继承AbstractHandleObj抽象类的实体集合
*/
public void deleteAll(Collection<AbstractHandleObj> hobjList);

/**
* 根据主键值获得继承AbstractHandleObj的实体
* @param entityName 继承AbstractHandleObj抽象类的实体名称(注:包含包名)
* @param id 实体主键
* @return AbstractHandleObj
*/
public AbstractHandleObj findByID(String entityName, String id);

/**
* 根据hql语句查找AbstractHandleObj,返回List<AbstractHandleObj>类型
* @param hql HQL查询语句
* @return List<AbstractHandleObj>
*/
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuery(String hql);

/**
* 根据hql语句查找AbstractHandleObj,返回List<AbstractHandleObj>类型
* @param hql HQL查询语句
* @param obj 查询参数,匹配站位符?
* @return List<AbstractHandleObj>
*/
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuery(String hql, Object obj);

/**
* 根据hql语句查找AbstractHandleObj,返回List<AbstractHandleObj>类型
* @param hql HQL查询语句
* @param objs 查询参数数组,按顺序匹配站位符?
* @return List<AbstractHandleObj>
*/
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuery(String hql, Object[] objs);

/**
* 根据hql语句查找某些列,返回List<Object[]>类型
* @param hql HQL查询语句
* @return List<Object[]>
*/
public List<Object[]> findColsByHqlQuery(String hql);

/**
* 根据hql语句查找某些列,返回List<Object[]>类型
* @param hql HQL查询语句
* @param obj 查询参数,匹配站位符?
* @return List<Object[]>
*/
public List<Object[]> findColsByHqlQuery(String hql, Object obj);

/**
* 根据hql语句查找某些列,返回List<Object[]>类型
* @param hql HQL查询语句
* @param objs 查询参数数组,按顺序匹配站位符?
* @return List<Object[]>
*/
public List<Object[]> findColsByHqlQuery(String hql, Object[] objs) ;

/**
* 根据hql语句查找某些列,返回List<Object>类型
* @param hql HQL查询语句
* @return List<Object>
*/
public List<Object> findColByHqlQuery(String hql) ;

/**
* 根据hql语句查找某些列,返回List<Object>类型
* @param hql HQL查询语句
* @param obj 查询参数,匹配站位符?
* @return List<Object>
*/
public List<Object> findColByHqlQuery(String hql, Object obj);

/**
* 根据hql语句查找某些列,返回List<Object>类型
* @param hql HQL查询语句
* @param objs 查询参数数组,按顺序匹配站位符?
* @return List<Object>
*/
public List<Object> findColByHqlQuery(String hql, Object[] objs);

/**
* 根据hql语句查找某些列,返回List<String[]>类型,支持分页
* @param hql HQL查询语句
* @param start 查找记录数其实位置(从0开始)
* @param reCount 要返回的记录数(页显示记录数)
* @return List<Object[]>
*/
public List<Object[]> findColsByHqlQuerySupportPaging(String hql, int start, int reCount);

/**
* 根据hql语句查找某些列,返回List<String[]>类型,支持分页
* @param hql HQL查询语句
* @param objs 查询参数数组,按顺序匹配站位符?
* @param types 查询参数类型数组,按顺序对应objs中的参数类型
* 注:参数必须是Hibernate类型的,比如String对应Hibernate.STRING,boolean对应Hibernate.BOOLEAN等
* @param start 查找记录数其实位置(从0开始)
* @param reCount 要返回的记录数(页显示记录数)
* @return List<Object[]>
*/
public List<Object[]> findColsByHqlQuerySupportPaging(String hql, Object[] objs,
Type[] types, int start, int reCount);

/**
* 根据hql语句查找,获得记录数
* 例如:select count(*) from T
* @param hql HQL查询语句
* @return long
*/
public long getRecordCountByHqlQuery(String hql) ;

/**
* 根据hql语句查找,获得记录数
* 例如:select count(*) from T where ...
* @param hql HQL查询语句
* @param obj 查询参数,匹配站位符?
* @return long
*/
public long getRecordCountByHqlQuery(String hql, Object obj) ;

/**
* 根据hql语句查找,获得记录数
* 例如:select count(*) from T where ...
* @param hql
* @param objs 查询参数数组,按顺序匹配站位符?
* @return long
*/
public long getRecordCountByHqlQuery(String hql, Object[] objs) ;

/**
* 执行更新update/删除delete操作
* @param hql
* @return int 更新数量/删除数量
*/
public int executeHqlQuery(String hql) ;

/**
* 执行更新update/删除delete操作
* @param hql
* @param obj 查询参数,匹配站位符?
* @return int 更新数量/删除数量
*/
public int executeHqlQuery(String hql, Object obj);

/**
* 执行更新update/删除delete操作
* @param hql
* @param objs 查询参数数组,按顺序匹配站位符?
* @return int 更新数量/删除数量
*/
public int executeHqlQuery(String hql, Object[] objs) ;

/**
* 根据hql语句查找AbstractHandleObj,返回List<AbstractHandleObj>类型,支持分页
* @param hql HQL查询语句
* @param start 查找记录数其实位置(从0开始)
* @param reCount 要返回的记录数(页显示记录数)
* @return List<AbstractHandleObj>
*/
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuerySupportPaging(String hql,
int start, int reCount);

/**
* 根据hql语句查找AbstractHandleObj,返回List<AbstractHandleObj>类型,支持分页
* @param hql HQL查询语句
* @param objs 查询参数数组,按顺序匹配站位符?
* @param types 查询参数类型数组,按顺序对应objs中的参数类型
* 注:参数必须是Hibernate类型的,比如String对应Hibernate.STRING,boolean对应Hibernate.BOOLEAN等
* @param start 查找记录数其实位置(从0开始)
* @param reCount 要返回的记录数(页显示记录数)
* @return List<AbstractHandleObj>
*/
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuerySupportPaging(String hql, Object[] objs,
Type[] types, int start, int reCount) ;

/**
* 支持SQL查询,根据sql语句查找某些列,返回List<String[]>类型
* @param sql SQL查询语句
* @return List<Object[]>
*/
public List<Object[]> findColsBySqlQuery(String sql) ;

/**
* 支持SQL查询,根据sql语句查找某列,返回List<Object>类型
* @param sql SQL查询语句
* @return List<Object>
*/
public List<Object> findColBySqlQuery(String sql) ;

/**
* 支持SQL操作,执行sql语句update/delete/存储过程
* @param sql SQL语句
* @return int
*/
public int executeSqlQuery(String sql) ;

}



看下实现类BaseDaoImpl.java:

package lym.dao.base.hibernate;

import java.io.Serializable;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

import lym.dao.obj.AbstractHandleObj;

import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.type.Type;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;


/**
* 基础Dao接口,实现通用操作
* @author 林元脉
* @version v1.1 2009/07/17
*
*/
public class BaseDaoImpl extends HibernateDaoSupport implements IBaseDao {


/**
* 对于返回列表的方法,通过调用我来实现返回记录数的控制,
* 设置返回记录数,若top为0不设置
*/
public void setMaxResults(int top){
if(top > 0){
getHibernateTemplate().setMaxResults(top);
}
}

public Serializable save(AbstractHandleObj hobj){
return getHibernateTemplate().save(hobj);
}

public void update(AbstractHandleObj hobj) {
getHibernateTemplate().update(hobj);

}

public void saveOrUpdate(AbstractHandleObj hobj) {
getHibernateTemplate().saveOrUpdate(hobj);

}

public void saveOrUpdateAll(Collection<AbstractHandleObj> hobjList) {
getHibernateTemplate().saveOrUpdateAll(hobjList);
}

public void delete(AbstractHandleObj hobj) {
getHibernateTemplate().delete(hobj);
}

public void deleteAll(Collection<AbstractHandleObj> hobjList) {
getHibernateTemplate().deleteAll(hobjList);
}

public AbstractHandleObj findByID(String entityName, String id)
{
return (AbstractHandleObj) getHibernateTemplate().get(entityName, id);
}

@SuppressWarnings("unchecked")
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuery(String hql)
{
List<AbstractHandleObj> resultList = new ArrayList<AbstractHandleObj>();
resultList = getHibernateTemplate().find(hql);
return resultList;
}

@SuppressWarnings("unchecked")
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuery(String hql, Object obj)
{
List<AbstractHandleObj> resultList = new ArrayList<AbstractHandleObj>();
resultList = getHibernateTemplate().find(hql, obj);
return resultList;
}

@SuppressWarnings("unchecked")
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuery(String hql, Object[] objs)
{
List<AbstractHandleObj> resultList = new ArrayList<AbstractHandleObj>();
resultList = getHibernateTemplate().find(hql, objs);
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object[]> findColsByHqlQuery(String hql)
{
List<Object[]> resultList = getHibernateTemplate().find(hql);
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object[]> findColsByHqlQuery(String hql, Object obj)
{
List<Object[]> resultList = getHibernateTemplate().find(hql, obj);
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object[]> findColsByHqlQuery(String hql, Object[] objs)
{
List<Object[]> resultList = getHibernateTemplate().find(hql, objs);
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object> findColByHqlQuery(String hql)
{
List<Object> resultList = getHibernateTemplate().find(hql);
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object> findColByHqlQuery(String hql, Object obj)
{
List<Object> resultList = getHibernateTemplate().find(hql, obj);
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object> findColByHqlQuery(String hql, Object[] objs)
{
List<Object> resultList = getHibernateTemplate().find(hql, objs);
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object[]> findColsByHqlQuerySupportPaging(final String hql,final int start,
final int reCount) {
List<Object[]> resultList = getHibernateTemplate().executeFind(new HibernateCallback(){
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Query query = session.createQuery(hql);
query.setFirstResult(start);
query.setMaxResults(reCount);

return query.list();
}
});
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object[]> findColsByHqlQuerySupportPaging(final String hql,
final Object[] objs, final Type[] types, final int start, final int reCount)
{
List<Object[]> resultList = getHibernateTemplate().executeFind(new HibernateCallback(){
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Query query = session.createQuery(hql);
/*设置参数*/
query.setParameters(objs, types);
query.setFirstResult(start);
query.setMaxResults(reCount);

return query.list();
}
});
return resultList;
}

public long getRecordCountByHqlQuery(String hql) {
long recordCount = (Long) getHibernateTemplate().find(hql).get(0);
return recordCount;
}

public long getRecordCountByHqlQuery(String hql, Object obj) {
long recordCount = (Long) getHibernateTemplate().find(hql, obj).get(0);
return recordCount;
}

public long getRecordCountByHqlQuery(String hql, Object[] objs) {
long recordCount = (Long) getHibernateTemplate().find(hql, objs).get(0);
return recordCount;
}

public int executeHqlQuery(String hql) {
return getHibernateTemplate().bulkUpdate(hql);
}

public int executeHqlQuery(String hql, Object obj) {
return getHibernateTemplate().bulkUpdate(hql, obj);
}

public int executeHqlQuery(String hql, Object[] objs) {
return getHibernateTemplate().bulkUpdate(hql, objs);
}

@SuppressWarnings("unchecked")
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuerySupportPaging(final String hql,
final int start, final int reCount) {
List<AbstractHandleObj> resultList = getHibernateTemplate().executeFind(new HibernateCallback(){
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Query query = session.createQuery(hql);
query.setFirstResult(start);
query.setMaxResults(reCount);

return query.list();
}
});
return resultList;
}

@SuppressWarnings("unchecked")
public List<AbstractHandleObj> findAbstractHandleObjByHqlQuerySupportPaging(final String hql, final Object[] objs,
final Type[] types, final int start, final int reCount) {
List<AbstractHandleObj> resultList = getHibernateTemplate().executeFind(new HibernateCallback(){
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
Query query = session.createQuery(hql);
/*设置参数*/
query.setParameters(objs, types);
query.setFirstResult(start);
query.setMaxResults(reCount);

return query.list();
}
});
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object[]> findColsBySqlQuery(final String sql) {
List<Object[]> resultList = new ArrayList<Object[]>();
Session session = getHibernateTemplate().getSessionFactory().openSession();
resultList = session.createSQLQuery(sql).list();
session.close();
return resultList;
}

@SuppressWarnings("unchecked")
public List<Object> findColBySqlQuery(String sql) {
List<Object> resultList = new ArrayList<Object>();
Session session = getHibernateTemplate().getSessionFactory().openSession();
resultList = session.createSQLQuery(sql).list();
session.close();
return resultList;
}

public int executeSqlQuery(final String sql) {
int result = 0;
Session session = getHibernateTemplate().getSessionFactory().openSession();
result = session.createSQLQuery(sql).executeUpdate();
session.close();
return result;
}
}



现在我来说说抽象类AbstractHandleObj.java的作用,先看下代码,其实也就一个抽象类,空类!

package lym.dao.obj;

/**
* 抽象类,为了实现通用基础Dao而定义的,
* 让实体来继承(需要返回的对象也继承他)
* @author 林元脉
* @version v1.0 2009/07/05
*
*/
public abstract class AbstractHandleObj {

}


建立这个抽象类的目的,其实就是让实体继承,或者返回对象继承他,这样就可以通过dao对实体进行操作,这也是使用这个dao对实体进行操作的前提条件!当然,如果不继承的话你也可以

因为我们项目使用的是spring+hibernate开发的,所以配置的话:

<bean id="baseDao" class="lym.dao.base.hibernate.BaseDaoImpl">
<!--注入sessionFactory-->
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>

我想目前存在的缺点是对命名参数的支持,大家给补上吧!
所有业务逻辑类皆可调用该类 package com.parddu.dao; import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.util.ArrayList; import java.util.HashMap; import java.util.List; /** * 通用DAO类 * @author parddu * @version Sep 29, 2010 10:16:23 AM */ public class CommonDAO { /** * 修改数据 * @param sql sql语句 * @param param 参数列表 * @return 修改记录行数 */ public int update(String sql,List param){ int row = -1; Connection conn = null; PreparedStatement update = null; try { conn = DButil.getConn(); update = conn.prepareStatement(sql); this.setParam(update, param); row = update.executeUpdate(); } catch (Exception e) { throw new RuntimeException(e.getMessage()); } finally{ DButil.closeConn(update, conn); } return row; } /** * 查询数据 * @param sql sql语句 * @param param 参数 * @return 结果集HashMap<列名,值对象> */ public List<HashMap> query(String sql,List param) { List<HashMap> list = new ArrayList<HashMap>(); Connection conn = null; PreparedStatement query = null; ResultSet rs = null; try { conn = DButil.getConn(); query = conn.prepareStatement(sql); this.setParam(query, param); rs = query.executeQuery(); if(rs!=null){ //取得所有的列名 ResultSetMetaData rsmd = rs.getMetaData(); int columnCount = rsmd.getColumnCount(); String[] columnNameArray = new String[columnCount]; for(int i=0;i<columnCount;i++){ columnNameArray[i] = rsmd.getColumnName(i+1); } //读取结果 while(rs.next()){ HashMap<String,Object> hm = new HashMap<String,Object>(); for(String cn : columnNameArray){ hm.put(cn, rs.getObject(cn)); } list.add(hm); } } } catch (Exception e) { throw new RuntimeException(e.getMessage()); } finally{ DButil.closeConn(rs,query, conn); } return list; } /** * 查询数据 * @param sql sql语句 * @param param 参数 * @return 结果集List<实体对象> */ public List query(String sql,List param,Class cla){ List list = new ArrayList(); Connection conn = null; PreparedStatement query = null; ResultSet rs = null; try { conn = DButil.getConn(); query = conn.prepareStatement(sql); this.setParam(query, param); rs = query.executeQuery(); if(rs!=null){ //取得所有的列名 ResultSetMetaData rsmd = rs.getMetaData(); int columnCount = rsmd.getColumnCount(); String[] columnNameArray = new String[columnCount]; for(int i=0;i<columnCount;i++){ columnNameArray[i] = rsmd.getColumnName(i+1); } //得到所有列和方法匹配的项 List<PropertyMthod> mList = new ArrayList<PropertyMthod>(); for(String columnName : columnNameArray){ Method m = this.getMethod(cla,columnName); if(m!=null){ PropertyMthod pm = new PropertyMthod(m,columnName); mList.add(pm); } } //读取结果 while(rs.next()){ Object o = cla.newInstance(); for(PropertyMthod pm : mList){ this.invokeSetMethod(o, pm.getMethod(), rs, pm.getColumn()); } list.add(o); } } } catch (Exception e) { throw new RuntimeException(e.getMessage()); } finally{ DButil.closeConn(rs,query, conn); } return list; } /** * 调用目标对象的set方法 * @param o 目标对象 * @param m set方法 * @param rs 结果集 * @param columnName 列名 * @throws SecurityException * @throws NoSuchMethodException * @throws IllegalArgumentException * @throws IllegalAccessException * @throws InvocationTargetException */ private void invokeSetMethod(Object o,Method m,ResultSet rs,String columnName) throws SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException{ String paramType = m.getParameterTypes()[0].getName(); paramType = paramType.substring(paramType.lastIndexOf(".")+1); /*****特殊类型处理******/ if("Integer".equals(paramType)){ paramType = "Int"; } String strName = "get" + this.firstUpper(paramType); Method rsMethod = rs.getClass().getDeclaredMethod(strName, String.class); m.invoke(o, rsMethod.invoke(rs, columnName)); } /** * 匹配指定列名的set方法 * @param o * @param column * @return * @throws NoSuchMethodException * @throws SecurityException */ private Method getMethod(Class o,String column) throws SecurityException, NoSuchMethodException{ Method m = null; List<String> strList = new ArrayList<String>(); /********set方法转换设置***********/ strList.add(column); //去掉下划线stu_name--->stuName strList.add(this.delLine(column,"_")); boolean flage = false; Method[] mlist = o.getDeclaredMethods(); for(Method tempm : mlist){ for(String s:strList){ String name = "set"+this.firstUpper(s); if(tempm.getName().equals(name)){ m=tempm; flage = true; break; } } if(flage){ break; } } if(!flage){ System.out.println("查询列名" + column + "在实体中无方法名匹配,值将不会被设置!"); } return m; } /** * 删除列分割符 * @return */ private String delLine(String str,String fg){ String result = str; if(str.indexOf(fg)!=-1){ result = str.substring(0,str.indexOf(fg))+ this.firstUpper(str.substring(str.indexOf(fg)+1)); result = delLine(result,fg); } return result; } /** * 将给定字符串首字母修改为小写 * @param str 字符串 * @return 转换后的字符串 */ private String firstUpper(String str){ return (str.charAt(0)+"").toUpperCase()+str.substring(1); } /** * 设置参数 * @param ps 预编译对象 * @param param 参数集合 * @throws SQLException */ private void setParam(PreparedStatement ps,List param) throws SQLException{ if(param!=null&&param;.size()>0){ for(int i=0;i<param.size();i++){ ps.setObject(i+1, param.get(i)); } } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值