hibernate的Dao层应该怎么改写?
hibernate自动生成的Dao层,无法两个或两个以上字段同时查询的,如果要查询两个字段都符合条件的结果集,我的做法就是在Dao层增加一个方法,然后通过HQL语句查询,...
hibernate自动生成的Dao层,无法两个或两个以上字段同时查询的,如果要查询两个字段都符合条件的结果集,我的做法就是在Dao层增加一个方法,然后通过HQL语句查询,但是我发现这样做,那Dao层要增加很多方法,而且Service层有一些就是直接调用Dao层的方法,有点不合理。
下面是我写的一段Dao层代码:
public List<Question> findPublicByCourse(String course_id, int page,int count){
Session session = getSession();
try {
List<Question> list = (List<Question>) session.createQuery("select q from Question as q where q.status=2 and q.course.id='"+course_id+"'").setFirstResult(page *count).setMaxResults(count).list();
return list;
} catch (RuntimeException re) {
throw re;
}finally {
session.flush();
session.close();
}
}
然后Service层调用它的代码如下:
public List<Question> findPublicByCourse(String course_id, int page,int count) {
List<Question> list=questionDAO.findPublicByCourse(course_id, page, count);
return list;
}
这样做,就是加入我要查某个人提出的关于某个课程的问题,就要又在Dao层写这样一个方法。
求更好的解决办法,应该怎么修改? 展开
下面是我写的一段Dao层代码:
public List<Question> findPublicByCourse(String course_id, int page,int count){
Session session = getSession();
try {
List<Question> list = (List<Question>) session.createQuery("select q from Question as q where q.status=2 and q.course.id='"+course_id+"'").setFirstResult(page *count).setMaxResults(count).list();
return list;
} catch (RuntimeException re) {
throw re;
}finally {
session.flush();
session.close();
}
}
然后Service层调用它的代码如下:
public List<Question> findPublicByCourse(String course_id, int page,int count) {
List<Question> list=questionDAO.findPublicByCourse(course_id, page, count);
return list;
}
这样做,就是加入我要查某个人提出的关于某个课程的问题,就要又在Dao层写这样一个方法。
求更好的解决办法,应该怎么修改? 展开
2个回答
展开全部
这种东西很常见,只是关于参数的问题的 可以这么实现,
比如你的参数是有1,2,3 那service层就写这3个参数的方法。
然后再dao层进行参数的判断,比如你只要查1,3限制条件的,
那service层上面层的action层里往service层传参数时候2应该是等于null,因为没有选2不是吗
那就在dao层对每个1,2,3参数进行判断
比如 1,3
可以写成
from XXX表
where
if(XXX1!=NULL){写1的限制}else{}
if(XX2!=null){写2的限制}else{}
if(xxx3!=null){写3的限制}else{}
只是在正常的共用语句之前进行了判断
希望对你有所帮助
比如你的参数是有1,2,3 那service层就写这3个参数的方法。
然后再dao层进行参数的判断,比如你只要查1,3限制条件的,
那service层上面层的action层里往service层传参数时候2应该是等于null,因为没有选2不是吗
那就在dao层对每个1,2,3参数进行判断
比如 1,3
可以写成
from XXX表
where
if(XXX1!=NULL){写1的限制}else{}
if(XX2!=null){写2的限制}else{}
if(xxx3!=null){写3的限制}else{}
只是在正常的共用语句之前进行了判断
希望对你有所帮助
2013-08-24
展开全部
可以写关联的HQL的
String hql="select q from Question q JOIN user u where u.name=:uname";
Query q=session.createQuery(hql).setString("uname", userName)
.setFirstResult(page *count)
.setMaxResults(count);
List<Question> list = (List<Question>) q.list();
String hql="select q from Question q JOIN user u where u.name=:uname";
Query q=session.createQuery(hql).setString("uname", userName)
.setFirstResult(page *count)
.setMaxResults(count);
List<Question> list = (List<Question>) q.list();
追问
假如有三个字段1,2,3,这个方法我要查字段1=?且字段3=?的记录,另一个方法要查字段2=?且字段3=?,还有一个要查字段1=?且字段2=?且字段3=?。这种能合并到一起成一个方法么?或者有更好的写法么?
追答
当然可以了。
根据查询条件,设置不同的查询参数就是,只是多使用一些if来判断。
这个会方便很多
Query
setParameters(Object[] values,
Type[] types)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询