博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DAO层使用泛型的两种方式
阅读量:7085 次
发布时间:2019-06-28

本文共 7027 字,大约阅读时间需要 23 分钟。

1.DAO层使用泛型类,主要是定义一些通用的增删改查,然后其他DAO的类都来继承该类,通过构造方法将class对象传给该泛型类

定义泛型接口

package sanitation.dao; import java.util.List; /**  *  * @param 
*/ public interface GenericDAO
{
/** * 通过ID获得实体对象 * * @param id实体对象的标识符 * @return 该主键值对应的实体对象 */ T findById(int id); /** * 将实体对象持久化 * * @param entity 需要进行持久化操作的实体对象 * @return 持久化的实体对象 */ T makePersitent(T entity); /** * 将实体变为瞬态 * * @param entity需要转变为瞬态的实体对象 */ void makeTransient(T entity); /** * 将一系列的实体变为瞬态,使用本地sql * * @param hql */ void makeTransientByIds(String sql); /** * * 使用hql语句进行分页操作 * * @param hql * @param offset 第一条记录索引 * @param pageSize 每页需要显示的记录数 * @return 查询的记录 */ List
findByPage(final String hql,final int offset,final int pageSize); /** * 使用hql 语句进行分页查询操作 * * @param hql 需要查询的hql语句 * @param value 如果hql有一个参数需要传入,value就是传入的参数 * @param offset 第一条记录索引 * @param pageSize 每页需要显示的记录数 * @return 当前页的所有记录 */ List
findByPage(final String hql , final Object value , final int offset, final int pageSize); /** * 使用hql 语句进行分页查询操作 * * @param hql 需要查询的hql语句 * @param values 如果hql有一个参数需要传入,value就是传入的参数 * @param offset 第一条记录索引 * @param pageSize 每页需要显示的记录数 * @return 当前页的所有记录 */ List
findByPage(final String hql, final Object[] values, final int offset, final int pageSize); /** * 使用sql 语句进行分页查询操作 * * @param sql * @param offset * @param pageSize * @return */ List findByPageSQL(final String sql, final int offset, final int pageSize); /** * 根据语句查找总数 * @param hql hql语句 * @return 对应的数目 */ Integer getCount(String hql); void updateObj(final String hql,final Object[] values); }

定义实现类

package sanitation.dao.impl; import java.sql.SQLException; import java.util.List; import org.hibernate.HibernateException; import org.hibernate.Query; import org.hibernate.Session; import org.springframework.orm.hibernate3.HibernateCallback; import org.springframework.orm.hibernate3.support.HibernateDaoSupport; import sanitation.dao.GenericDAO; public class GenericHibernateDAO
extends HibernateDaoSupport implements GenericDAO
{
private Class
persistentClass; public GenericHibernateDAO(Class
persistentClass){
this.persistentClass=persistentClass; } public Class
getPersistentClass(){
return persistentClass; } @SuppressWarnings("unchecked") public T findById(int id) {
return (T)getHibernateTemplate().get(getPersistentClass(), id); } @SuppressWarnings("unchecked") public List
findByPage(final String hql, final int offset, final int pageSize){ List
list= getHibernateTemplate().executeFind(new HibernateCallback(){ public Object doInHibernate(final Session session) throws HibernateException, SQLException{ Query query=session.createQuery(hql); if(!(offset==0 && pageSize==0)){ query.setFirstResult(offset).setMaxResults(pageSize); } List
result = query.list(); return result; } }); return list; } @SuppressWarnings("unchecked") public List findByPageSQL(final String sql, final int offset, final int pageSize){ List list= getHibernateTemplate().executeFind(new HibernateCallback(){ public Object doInHibernate(final Session session) throws HibernateException, SQLException{ Query query=session.createSQLQuery(sql); if(!(offset==0 && pageSize==0)){ query.setFirstResult(offset).setMaxResults(pageSize); } List result = query.list(); return result; } }); return list; } @SuppressWarnings("unchecked") public List
findByPage(final String hql, final Object value, final int offset, final int pageSize) { List
list = getHibernateTemplate().executeFind(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException, SQLException { Query query=session.createQuery(hql).setParameter(0, value); if(!(offset==0 && pageSize==0)){ query.setFirstResult(offset).setMaxResults(pageSize); } List
result = query.list(); return result; } }); return list; } @SuppressWarnings("unchecked") public List
findByPage(final String hql, final Object[] values, final int offset, final int pageSize) { List
list = getHibernateTemplate().executeFind(new HibernateCallback(){ public Object doInHibernate(Session session) throws HibernateException, SQLException{ Query query=session.createQuery(hql); for (int i = 0 ; i < values.length ; i++){ query.setParameter( i, values[i]); } if(!(offset==0 && pageSize==0)){ query.setFirstResult(offset).setMaxResults(pageSize); } List
result = query.list(); return result; } }); return list; } public void updateObj(final String hql, final Object[] values) { getHibernateTemplate().execute(new HibernateCallback(){ public Object doInHibernate(Session session) throws HibernateException, SQLException{ Query query=session.createQuery(hql); for(int i=0;i

2.而有时我们为了方便起见,对于一些简单的项目,DAO的操作很单一,不会有很复杂的操作,那么我们直接用泛型方法类代替泛型类,主要就不需要写其他的DAO来继承,

整个DAO层就一个DAO类。

接口:

package com.xidian.dao; import java.util.List; import com.xidian.bean.Admin; import com.xidian.bean.HostIntroduce; import com.xidian.bean.Reply; public interface CommonDAO {
public
void sava(T entity); //保存用户,无返回值; public
void remove(T entity); //删除用户 public
void update(T entity); //更新用户 public
T findById(Class
entityClass, Integer id); //通过id来查找某一个用户; public
List
findAll(Class
entityclass); //使用范型List<>,查询所有的用户信息 }

实现类:

package com.xidian.dao.impl; import java.util.List; import org.springframework.orm.hibernate3.support.HibernateDaoSupport; import com.xidian.bean.Admin; import com.xidian.bean.HostIntroduce; import com.xidian.bean.Reply; import com.xidian.dao.CommonDAO; public class CommonDAOImpl extends HibernateDaoSupport implements CommonDAO {
@SuppressWarnings("unchecked") @Override public
List
findAll(Class
entityclass) {
//String name = entity.getClass().getName(); String hql = "from "+entityclass.getName()+" as aaa order by aaa.id desc"; return this.getHibernateTemplate().find(hql); } @SuppressWarnings("unchecked") @Override public
T findById(Class
entityClass, Integer id) {
return (T) this.getHibernateTemplate().get(entityClass, id); } @Override public
void remove(T entity) { this.getHibernateTemplate().delete(entity); } @Override public
void sava(T entity) { this.getHibernateTemplate().save(entity); } @Override public
void update(T entity) { this.getHibernateTemplate().update(entity); } }

使用泛型可以使代码大大的精简

 

转载地址:http://hpgml.baihongyu.com/

你可能感兴趣的文章
Maven学习总结(四)——Maven核心概念
查看>>
linux shell中,单引号、 双引号,反引号(``),$()的区别
查看>>
Java8 十大新特性详解
查看>>
多线程的同步介绍
查看>>
开源js框架中各种你看不懂的js语法解释大全!!
查看>>
Mysql学习总结(9)——MySql视图原理讲解与使用大全
查看>>
linux挂载ipsan服务器
查看>>
Java持续集成(二)-- 整合以及使用
查看>>
什么是智能DNS解析?
查看>>
Mybatis应用学习(2)——配置文件编写
查看>>
一个图灵API的调用
查看>>
oracle-后台进程
查看>>
HTML5新特性:元素的classList属性与应用
查看>>
PHP开发会员系统
查看>>
asp.net c#轻松调用百度在线翻译功能
查看>>
我的友情链接
查看>>
DNS Server 3 子域的授权
查看>>
2013-05-25
查看>>
Initializing the Oracle ASMLib driver: [FAILED]
查看>>
innodb_force_recovery强制修复MySQL异常关闭问题
查看>>