`
lym6520
  • 浏览: 696096 次
  • 性别: Icon_minigender_1
  • 来自: 福建
社区版块
存档分类
最新评论

我给dao的瘦身方法请大虾拍砖!

    博客分类:
  • JAVA
阅读更多
上周上司提出要给dao瘦身(由业务层定义HQL语句,目前是将HQL语句定义在dao层),让我们想想有什么好的方法,通过周六、周日两天的思考,我提出了一个方案来,如下文:
1.定义一个通用dao,包含所有CURD的操作(因为HQL语句由业务层定义)
2.让所有实体(也可以使任意需要返回的对象)都继承至一个抽象类(“里氏代换原则”中说,任何基类可以出现的地方,子类一定可以出现。)
如图:


现在我们主要讨论下这两个方法:getReternObject和getReternObjectList,我们知道,这两个对象返回的对象是ReternObject和List<ReternObject>(这里ReternObject是一个抽象类),而返回的实际对象可能是EntityA、EntityB和EntityC的任意一个,根据“里氏代换原则”中说,任何基类可以出现的地方,子类一定可以出现。
我想说道这里大家应该很清楚我的用意了,比如说有一个这样的操作要获取EntityA,然后我们根据定义好的GeneralDao进行操作,通过业务层传入这样一条HQL语句:select a from EntityA where a.id = '01' ,这样我们就可以获得EntityA了,但好像很少人使用这样的方式来给dao瘦身,希望大虾们拍拍砖!这样做到底好不好!
  • 大小: 14.8 KB
分享到:
评论
15 楼 tianmo2008 2009-10-24  
lym6520 写道
上周上司提出要给dao瘦身(由业务层定义HQL语句,目前是将HQL语句定义在dao层),让我们想想有什么好的方法,通过周六、周日两天的思考,我提出了一个方案来,

我一直都喜欢把hql/sql语句定义在dao层的,但不直接写在代码里面,而是写在properties文件里,每个dao维护一个同名properties文件,自己觉得挺好的.
14 楼 lym6520 2009-07-10  
yuantong 写道
public class GenericDao<T, PK extends Serializable, DAOImpl extends IGenericDao<T, PK>>
extends HibernateDaoSupport implements IGenericDao<T, PK>

感觉泛型挺麻烦的!
13 楼 yuantong 2009-07-09  
public class GenericDao<T, PK extends Serializable, DAOImpl extends IGenericDao<T, PK>>
extends HibernateDaoSupport implements IGenericDao<T, PK>
12 楼 lym6520 2009-07-07  
大虾都上哪了呢?
11 楼 lym6520 2009-07-07  
...
10 楼 lym6520 2009-07-07  
为什么你们都喜欢利用泛型呢?有没有更好的方法!我提出的这种方法是否可行?
9 楼 allwefantasy 2009-07-07  
个人认为将所有的的持久化操作集合到一个类,通过依赖注入注入到action或者service层,直接调用注入对象进行持久化操作。类似于:
public class BaseImpl<T> implements IBaseDAO<T>
	{
		protected HibernateTemplate hibernateTemplate;
	
		public void setHibernateTemplate(HibernateTemplate hibernateTemplate)
			{
				this.hibernateTemplate = hibernateTemplate;
			}

	
	public void deleteEntity(T entity)
		{
			hibernateTemplate.delete(entity);
			
		}
	


	public void deleteEntity(Class clzz,Serializable id)
		{
			hibernateTemplate.delete(findEntity(clzz,id));
			
		}
               public void saveEntity(T entity)
		{
			hibernateTemplate.save(entity);
			
		}
}


假设在action注入的名字为baseDAO.
那么我们保存一个对性的时候可以直接用baseDAO.save(object);
同理查询也可以用补丁参数+Critiria构造,比如
public abstract List findEntityProperty(final Class clzz,
final Order order, final int start, final int num,
final Criterion... criterions);
就能支持常见的查询
8 楼 xyh 2009-07-07  
Dao层应该简化,请看我的帖子:http://xyh.iteye.com/blog/412876
7 楼 lym6520 2009-07-06  
所以我们才提出简化dao,想用一个dao来解决所有dao的操作!
6 楼 kjj 2009-07-06  
用久了dao,反而感到繁琐,增加不必要的代码,不必要的操作,该是反思一下dao的作用到底是啥玩意呢!!
5 楼 lym6520 2009-07-06  
我想dao可以看做是数据库的一个实例,是我们CURD操作的一个接口,services层通过dao层来访问数据库,这应该是面向对象的开发。
4 楼 kjj 2009-07-06  
那里臃肿了,增加dao层主要目的是啥呢!!
3 楼 lym6520 2009-07-06  
我现在用的构架是spring+hibernate的,总不可能把Dao层和services层混在一起吧!
2 楼 lym6520 2009-07-06  
当是这样的话,你的services层不是很臃肿吗?
1 楼 kjj 2009-07-06  
老实说,我已经把dao精简掉了,找不到他存在的必要性,直接action和service对话,必要的话,ajax直接绕过action和services对话

相关推荐

Global site tag (gtag.js) - Google Analytics