hibernate中如何执行mysql语句select * from work where month(date) = 3

bllizard 2009-05-27 04:47:22
hibernate中如何执行mysql语句select * from work where month(date) = 3
如果能用criteria解决更好
...全文
240 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
bllizard 2009-05-29
  • 打赏
  • 举报
回复
我自己写了如下函数:
public List order(){
SQLQuery query=getSession().createSQLQuery("select sum(salary),month(date) month from emp group by month(date) ");
List list=query.list();

return list;
}
最后我得到的是LIST类的一个对象

我现在想把其中的sum和mouth分别取出来,请问如何操作
sd3560531 2009-05-28
  • 打赏
  • 举报
回复
拿到hibernate session以后
SQLQuery query=session.createSQLQuery("select * from work where month(date) = 3 ");
List list=query.list();
所返回list就是执行sql语句的结果集

使用criteria:
假设你的work表对应的类名为Work
你所查询的条件month对应为类中属性month
Criteria criteria=session.createCriteria(Work.class,"w");
criteria.add(Restrictions.eq("w.month",3);
List list=criteria.list();
所返回list结果跟执行sql语句结果一样。
l36235405 2009-05-27
  • 打赏
  • 举报
回复
session.createCriteria(work.class).add(Restrictions.eq("month", 3)).list();

return (List) getHibernateTemplate().execute(
new HibernateCallback() {
public Object doInHibernate(Session session)
throws HibernateException {
return (List) session.createCriteria(work.class).add(Restrictions.eq("month", 3)).list();

67,538

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧