spring_hibernate2(IEmpDao)

package com.tarena.dao.impl;

import java.sql.SQLException;
import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.HibernateTemplate;

import com.tarena.dao.IEmpDao;
import com.tarena.po.Emp;

public class EmpDaoImpl implements IEmpDao {

	private HibernateTemplate hibernateTemplate;
//	注入SessionFactory
	public void setSessionFactory(SessionFactory sessionFactory){
		hibernateTemplate = new HibernateTemplate(sessionFactory);
	}
// 根据empno删除emp数据
	public void deleteById(int empno) {
		Emp emp = new Emp();
		emp.setEmpno(7934);
		hibernateTemplate.delete(emp);
	}

	public long findCount() {
		String hql = "select count(empno) from Emp";
		return (Long) hibernateTemplate.find(hql).get(0);
	}
// 根据id查询对象
	public Emp findEmpById(int empno) {
		
		return (Emp) hibernateTemplate.get(Emp.class, empno);
	}

	public List<Emp> findEmps() {
		// 要求只查询出5个属性的,使用hql的构造方法查询
		String hql = "select new com.tarena.po.Emp(empno,ename,job,sal) from Emp ";
		
		return hibernateTemplate.find(hql);
	}

	public List<Emp> findPage(final int firstResult, final int maxResult) {
//		hibernate 对分页的支持很好,只能使用回调调用session
		return (List<Emp>) hibernateTemplate.execute(new HibernateCallback(){
			public Object doInHibernate(Session session)
					throws HibernateException, SQLException {
				String hql = "from Emp";
				return session.createQuery(hql)
				.setFirstResult(firstResult)
				.setMaxResults(maxResult)
				.list();
			}
		});
	}

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值