Hibernate基于Spring模板的DAO基类
来源:互联网 发布:js 手写板插件 编辑:程序博客网 时间:2024/05/18 20:46
Spring通过模板类和支持类为各种ORM框架提供了出色的支持,但也存在不足。对于加载实体,查询实体的操作我们可以用泛型带来很大的便利。所以在Spring支持类的基础上编写自己的DAO基类,以获得泛型的支持并提供自己的代理方法使子类避免通过显式调用模板类实例进行数据操作。DAO基类仅对一些常用方法(CRUD)进行代理,不常用的方法要求子类显式调用模板实例完成。这样可简化常用方法的调用。
以Hibernate为例:
public class BaseDao<T> { //注入模板 @Autowired private HibernateTemplate hibernateTemplate; //子类所指定的T所对应的类型 private Class entityclass; //重点:通过反射方式获取子类Dao对应的泛型实体类 public BaseDao(T) { Type genType = getClass().getGenericSuperclass(); Type[] params = ((ParameterizdeType)genType).getActualTypeArguments(); entityClass = (Class)param[0]; } public T get(Serializable id) { return (T)hibernateTemplate.get(entityClass,id) } public void save(T entity) { hibernateTemplate.save(entity); } public void update(T entity) { hibernateTemplate.update(entity); } public HibernateTemplate getHibernateTemplate() { return hibernateTempalte; }}
然后可以通过扩展BaseDao得到一个被极大化简的UserDao:
public class UserDao extends BaseDao<User> { public long getUserNum() { Object obj = getHibernateTemplate().iterate("select count(u.userid) from User u").next(); return (Long)obj; }}
普通的增删改查方法直接从BaseDao中继承,如用户调用UserDao#get(Serializable id)加载实体对象时,将直接返回User类型的实体对象。
0 0
- Hibernate基于Spring模板的DAO基类
- 基于Spring+Hibernate+DAO的hibernate的lazy的实现.
- 基于Spring、Hibernate的通用DAO层与Service层的实现
- 基于Spring、Hibernate的通用DAO层与Service层的实现
- 基于Spring、Hibernate的通用DAO层与Service层的实现
- 基于Spring、Hibernate的通用DAO层与Service层的实现
- 基于Spring、Hibernate的通用DAO层与Service层的实现
- dao注入hibernate模板
- 基于hibernate的泛型Dao框架
- Hibernate泛型DAO(结合spring模板支持)
- 基于Hibernate编写DAO
- Spring+hibernate+junit的Dao测试
- Spring对Hibernate DAO的封装
- SpringMVC+Spring+hibernate+junit的Dao测试
- 基于Spring的DAO层设计
- 基于Spring的DAO层设计
- 基于Spring的DAO层设计
- 基于Spring的DAO层设计
- 落叶不懂的桑梓心
- 黑马程序员--集合框架和集合操作(List,Queue, Deque,Map)
- Oracle Decode()的使用
- 第十二章 动态内存
- cygwin下面编译proxmark3(at 2015.09.09)
- Hibernate基于Spring模板的DAO基类
- 欢迎使用CSDN-markdown编辑器
- JSON和Java实体之间的数据类型映射
- Leetcode: Gray Code
- 自绘button
- python语法检查利器pychecker
- 初窥Linux 之 ext2/ext3文件系统
- 网络IO模型
- Mysql中in和find_in_set的使用说明