`
kkllmey
  • 浏览: 103366 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

--BaseHibernateDao-高级

阅读更多
package net.music.util;

import java.lang.reflect.Field;
import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.FetchMode;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.criterion.Example;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
import org.springframework.dao.DataAccessException;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

/**
 * 
 * @author kkllmey Jul 7, 2008
 */
public class BaseHibernateDao extends HibernateDaoSupport {


 protected void save(Object entity) throws Exception {
  try {
   super.getHibernateTemplate().save(entity);
  } catch (DataAccessException e) {
   throw new Exception("save entity error kkll", e);
  }
 }


 protected void update(Object entity) throws Exception {
  try {
   super.getHibernateTemplate().update(entity);
  } catch (RuntimeException e) {
   throw new Exception("update entity error kkll", e);
  }
 }


 protected void delete(Object entity) throws Exception {
  try {
   super.getHibernateTemplate().delete(entity);
  } catch (RuntimeException e) {
   throw new Exception("del entity error kkll", e);
  }
 }


 protected <T> void delete(Class<T> cls, java.io.Serializable id)
   throws Exception {
  try {
   Object obj = this.get(cls, Integer.parseInt(id.toString()));
   super.getHibernateTemplate().delete(obj);
  } catch (Exception e) {
   throw new Exception("del entity error kkll", e);
  }
 }

 protected <T> T get(Class<T> cls, java.io.Serializable id) throws Exception {
  try {
   return (T) super.getHibernateTemplate().get(cls, id);
  } catch (RuntimeException e) {
   throw new Exception("get entity error kkll");
  }
 }


 @SuppressWarnings("unchecked")
 protected <T> List<T> search(Object entity, Class<T> cls, int pageSize,
   int currPage, boolean isASC, String ascKey, String... joins)
   throws Exception {
  try {
   Session session = super.getSession();
   Criteria cr = session.createCriteria(cls);
   
   for (String join : joins) {
    cr.setFetchMode(join, FetchMode.JOIN);
   }
   if (!"".equals(ascKey) && null != ascKey) {
    if (isASC) {
     cr.addOrder(Order.asc(ascKey));
    } else {
     cr.addOrder(Order.desc(ascKey));
    }
   }
   if (null != entity) {
    cr.add(Example.create(entity));
    fillCriteria(cr, entity);
   }
   cr.setFirstResult((currPage - 1) * pageSize);
   cr.setMaxResults(pageSize);
   List<T> lst = cr.list();
   //session.close();
   return lst;
  } catch (Exception e) {
   throw new Exception("exe hql error kkll", e);
  }
 }

 protected void fillCriteria(Criteria cr, Object entity) {
  Field[] fs = entity.getClass().getDeclaredFields();
  try {
   for (Field f : fs) {
    f.setAccessible(true);
    String temp = f.getType().getName();
    if (temp.indexOf("java.") == -1) {
     if (null != f.get(entity) && !"".equals(entity)) {
      if(f.get(entity).getClass().getDeclaredFields()[0].get(f.get(entity))!=null)
       cr.add(Restrictions.like(f.getName(), f.get(entity)));
     }
    }
    f.setAccessible(false);
   }
  } catch (SecurityException e) {
   e.printStackTrace();
  } catch (IllegalArgumentException e) {
   e.printStackTrace();
  } catch (IllegalAccessException e) {
   e.printStackTrace();
  }
 }


 protected <T> List<T> exeHql(String hql) throws Exception {
  try {
   Session session = super.getSession();
   List<T> lst = session.createQuery(hql).list();
   session.close();
   return lst;
  } catch (Exception e) {
   throw new Exception("exe hql error kkll", e);
  }
 }
 
 protected <T> List<T> exeHql(String hql, int currPage, int pageSize,
   List... paras) throws Exception {
  try {
   Session session = super.getSession();
   Query q = session.createQuery(hql);
   if(null!=paras&&0<paras.length)
    setParas(q, paras[0]);
   q.setFirstResult((currPage - 1) * pageSize);
   q.setMaxResults(pageSize);
   List<T> lst = q.list();
   session.close();
   return lst;
  } catch (Exception e) {
   throw new Exception("exe hql error kkll", e);
  }
 }
 protected void setParas(Query q, List paras) {
  if (paras != null && 0 < paras.size()) {
   try {
    for (int i = 0; i < paras.size(); i++) {
     String para = paras.get(i).getClass().getName();
     int lasxI=para.lastIndexOf(".")+1;
     String name = "set"+para.substring(lasxI,para.length());
     if(paras.get(i).getClass()==Integer.class)
      q.getClass().getMethod(name,int.class,int.class).invoke(q,i,paras.get(i));
     else
      q.getClass().getMethod(name,int.class,paras.get(i).getClass()).invoke(q,i,paras.get(i));
    }
   } catch (Exception ex) {
    ex.printStackTrace();
   }
  }
 }
}

 

分享到:
评论

相关推荐

    BaseHibernateDAO

    BaseHibernateDAO是用于获取数据库信息的公共访问类 有了它,数据增删改查将会更加方便

    hibernate学习随笔

    - **BaseHibernateDAO** 类是Epai系统中所有DAO类的基础,提供了通用的数据库操作方法,如查询、添加、更新和删除等。 - **方法解析**: - `getSession()`:返回一个 `Session` 对象,用于进行数据库操作。 - `...

    jasperreport excel报表打印

    - 通过`BaseHibernateDAO`类中的方法获取数据库连接。 - 使用Hibernate Session进行数据库查询操作。 - 将查询结果存储为List对象。 2. **报表设计**:利用jxl库控制Excel表格的显示效果。 - 创建Workbook对象...

    MyEclipse连接

    - BaseHibernateDAO.java: 基础DAO类 - HibernateSessionFactory.java: Hibernate Session工厂类 - IBaseHibernateDAO.java: DAO接口 - Sstest.java: 数据对象类 - SstestDAO.java: DAO实现类 8. **测试代码**...

    Struts2 + Hibernate开发笔记(二).txt

    baseHibernateDAO.update(iCity); // 更新数据库 } ``` - 注意:这里没有直接更新传入的`city`对象,而是先查询出对应的`iCity`对象,然后更新其属性,再进行保存。这是因为Hibernate管理的对象必须保持一致的...

    Hibernate配置过程

    - `BaseHibernateDAO`:这是一个通用的DAO基类,提供`getSession()`方法,其返回由`HibernateSessionFactory`创建的`Session`。子类可以继承这个基类,从而直接使用`getSession()`进行数据库操作。 ### Hibernate...

    ssh通用泛型DAO

    BaseHibernateDAO是基于Hibernate框架的一个基类,它封装了常见的数据库操作,如增删查改(CRUD)。通过继承这个基类,开发者可以快速创建自定义的DAO实现,避免重复编写相似的代码。BaseHibernateDAO通常会包含以下...

    使用maven整合spring和hibernate的例子(spring mvc)

    例如,我们可以创建一个通用的BaseHibernateDAO,提供基本的CRUD方法。Service层则封装了业务逻辑,调用DAO层的方法处理数据。 最后,在Controller层,我们创建对应的控制器类,使用@RequestMapping注解定义URL映射...

    java西安公司考试考试资源

    - `UserDao`扩展了`BaseHibernateDao`,继承了从HibernateSessionFactory获取Session的能力。`saveOrUpdate`和`delete`方法展示了如何使用Hibernate进行持久化操作。`saveOrUpdate`用于保存或更新对象,而`delete`...

    自动创建javebean

    - **基础DAO组件**:创建`IBaseHibernateDAO`接口和`BaseHibernateDAO`类,这些组件提供了基本的DAO功能,并依赖于`com.genuitec.hibernate.HibernateSessionFactory`类来获取Hibernate会话。 #### 知识点三:...

    SSH框架集成步骤

    public class BaseHibernateDAO extends HibernateDaoSupport { protected void add(Object item) { super.getHibernateTemplate().save(item); } //...其他数据访问方法 } ``` **2.3 配置事务管理器** 为了...

    青鸟一小部分教学.ppt

    8. **阶段3**:利用MyEclipse的Hibernate工具生成实体类和映射文件,创建BaseHibernateDAO基类,以简化DAO的实现,减少重复代码。 9. **阶段4**:对PetDiary实体类和映射文件进行重生成,并使用BaseHibernateDAO...

    Hibernate操作持久化对象

    在给定的代码片段中,`FwxxDAOHibImpl`类继承了`BaseHibernateDAO`并实现了`FwxxDAO`接口。这个类展示了如何使用Hibernate的简单操作,如`get()`, `add()`, `del()`, 和 `update()`方法,这些方法调用了基类的抽象...

    ssh环境搭建和简单示例

    进一步地,我们可以创建一个基类`BaseHibernateDAO`,封装通用的Hibernate操作。 **Spring与Hibernate的整合**主要涉及以下方面: 1. **配置数据源**:在Spring的`applicationContext.xml`中定义数据源(`...

    java实现遍历树形菜单两种实现代码分享

    该实现中,OpenSessionView类继承自BaseHibernateDao类,并实现了Filter接口。 在doFilter方法中,首先获取了Session对象,然后开始事务,接着执行FilterChain的doFilter方法,以便将请求传递给下一个Filter或...

Global site tag (gtag.js) - Google Analytics