import java.util.List;
import org.hibernate.HibernateException;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.criterion.Example;
public class BaseHibernateDao {
private Session session=null;
private static SessionFactory sf;
public void setSession(Session session){
this.session=session;
}
protected Session getSession(){
if(session!=null){
return session;
}
else if(sf!=null){
session=sf.openSession();
return session;
}
Configuration cfg=new Configuration().configure();
sf=cfg.buildSessionFactory();
this.session=sf.openSession();
return session;
}
/* insert */
protected boolean add(Object item){
Session session=getSession();
Transaction tran=null;
boolean is=false;
try{
tran=session.beginTransaction();
session.save(item);
tran.commit();
is=true;
}catch(Exception e){
if(null!=tran)
tran.rollback();
e.printStackTrace();
}finally{
closeSession();
}
return is;
}
/* update */
protected boolean update(Object item){
Session session=getSession();
Transaction tran=null;
boolean is=false;
try{
tran=session.beginTransaction();
session.update(item);
tran.commit();
is=true;
}catch(Exception e){
if(tran!=null)
tran.rollback();
e.printStackTrace();
}finally{
closeSession();
}
return is;
}
/* delete (根据实体删除) */
protected boolean delete(Object item){
Session session=getSession();
Transaction tran=null;
boolean is=false;
try{
tran=session.beginTransaction();
session.delete(item);
tran.commit();
return is;
}catch (Exception e) {
if(tran!=null)
tran.rollback();
e.printStackTrace();
}finally{
closeSession();
}
return is;
}
/*根据主键删除(只能先查后删)*/
protected boolean delete(Class cls,java.io.Serializable id){
Session session = getSession();
boolean is =false;
try{
Object obj = select(cls, id);
session.delete(obj);
session.getTransaction().commit();
is=true;
}catch(HibernateException e){
if(null!=session)
session.getTransaction().rollback();
e.printStackTrace();
}
return is;
}
/* 根据主键查询 */
protected Object select(Class cls,java.io.Serializable id){
Object obj=null;
try {
obj = getSession().get(cls, id);
} catch (HibernateException e) {
e.printStackTrace();
} finally{
closeSession();
}
return obj;
}
/* select (根据对象查询:对象初始化的属性越多,查询条件越多) */
protected List select (Class clazz,Object obj){
List result= null;
try{
result=getSession().createCriteria(clazz).add(Example.create(obj)).list();
return result;
}catch(Exception e){
e.printStackTrace();
}finally{
closeSession();
}
return result;
}
/* 关闭session */
protected void closeSession(){
if(session!=null){
session.close();
session=null;
}
}
}
分享到:
相关推荐
- 通过`BaseHibernateDAO`类中的方法获取数据库连接。 - 使用Hibernate Session进行数据库查询操作。 - 将查询结果存储为List对象。 2. **报表设计**:利用jxl库控制Excel表格的显示效果。 - 创建Workbook对象...
例如,我们可以创建一个通用的BaseHibernateDAO,提供基本的CRUD方法。Service层则封装了业务逻辑,调用DAO层的方法处理数据。 最后,在Controller层,我们创建对应的控制器类,使用@RequestMapping注解定义URL映射...
8. **阶段3**:利用MyEclipse的Hibernate工具生成实体类和映射文件,创建BaseHibernateDAO基类,以简化DAO的实现,减少重复代码。 9. **阶段4**:对PetDiary实体类和映射文件进行重生成,并使用BaseHibernateDAO...
在给定的代码片段中,`FwxxDAOHibImpl`类继承了`BaseHibernateDAO`并实现了`FwxxDAO`接口。这个类展示了如何使用Hibernate的简单操作,如`get()`, `add()`, `del()`, 和 `update()`方法,这些方法调用了基类的抽象...