struts+hibernate+oracle+easyui实现lazyout组件的简单案例——EmpDao层代码

简介: struts+hibernate+oracle+easyui实现lazyout组件的简单案例——EmpDao层代码

  严格按照三层架构来写的,Dao层的代码比较少,我直接把Emp和实现类的都放在这篇文章里面吧,

IEmpDao.java接口:


/**  
* @Title: IEmpDao.java
* @Package org.dao
* @Description: TODO该方法的主要作用:
* @author A18ccms A18ccms_gmail_com  
* @date 2017-4-19 下午6:36:43
* @version V1.0  
*/
package org.dao;
import org.entity.Emp;
import org.entity.EmpCondition;
import org.util.pageUtil;
 /**   
 *    
 * 项目名称:struts_easyui   
 * 类名称:IEmpDao   
 * 类描述:   员工的接口
 * 创建人:Mu Xiongxiong  
 * 创建时间:2017-4-19 下午6:36:43   
 * 修改人:Mu Xiongxiong   
 * 修改时间:2017-4-19 下午6:36:43   
 * 修改备注:   
 * @version    
 *    
 */
public interface IEmpDao {
  //动态分页查询(根据部门编号,员工的名)
  //获取记录数
  //获取员工信息方法
  pageUtil<Emp> getEmpByPage(int pageIndex,int pageSize,EmpCondition empc);
}


IEmpDao的实现类——EmpDaoImpl

/**  
* @Title: EmpDaoImpl.java
* @Package org.dao.impl
* @Description: TODO该方法的主要作用:
* @author A18ccms A18ccms_gmail_com  
* @date 2017-4-19 下午7:15:46
* @version V1.0  
*/
package org.dao.impl;
import org.dao.IEmpDao;
import org.entity.Emp;
import org.entity.EmpCondition;
import org.hibernate.Criteria;
import org.hibernate.criterion.MatchMode;
import org.hibernate.criterion.Projection;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.hibernate.impl.CriteriaImpl;
import org.util.HibernateUtil;
import org.util.pageUtil;
 /**   
 *    
 * 项目名称:struts_easyui   
 * 类名称:EmpDaoImpl   
 * 类描述:   
 * 创建人:Mu Xiongxiong  
 * 创建时间:2017-4-19 下午7:15:46   
 * 修改人:Mu Xiongxiong   
 * 修改时间:2017-4-19 下午7:15:46   
 * 修改备注:   
 * @version    
 *    
 */
public class EmpDaoImpl implements IEmpDao {
  /**(非 Javadoc)
   * <p>Title: getEmpByPage</p>
   * <p>Description(描述): </p>
   * @param pageIndex
   * @param pageSize
   * @param empc
   * @return
   * @see org.dao.IEmpDao#getEmpByPage(int, int, org.entity.EmpCondition)
   */
  @Override
  public pageUtil<Emp> getEmpByPage(int pageIndex, int pageSize,
      EmpCondition empc) {
    pageUtil<Emp> pageUtil=new pageUtil<Emp>();
    Criteria cri = HibernateUtil.getSession().createCriteria(Emp.class);
    if(empc.getDept()!=null){
      cri.add(Restrictions.eq("dept",empc.getDept()));       //按部门编号比较
    }
    if(empc.getEmpName()!=null){
      //根据名字模糊查询
      cri.add(Restrictions.ilike("ename", empc.getEmpName(),MatchMode.ANYWHERE));  
    }
    pageUtil.setPageIndex(pageIndex);
    pageUtil.setPageSize(pageSize);
    CriteriaImpl cirImp= (CriteriaImpl) cri; 
    
    Projection pro= cirImp.getProjection();//保存投影
    //查询总记录数
    cri.setProjection(Projections.rowCount());
    pageUtil.setTotalCount((Integer)cri.uniqueResult());
    //员工信息
    cri.setProjection(pro);
    //分页设置
    cri.setFirstResult((pageIndex-1)*pageSize);
    cri.setMaxResults(pageSize);
    pageUtil.setList(cri.list());
    return pageUtil;
  }
}


相关文章
|
8月前
|
JavaScript 前端开发 Java
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——Jsp页面
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——Jsp页面
|
8月前
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——OpSessionview实现
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——OpSessionview实现
|
8月前
|
Java
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——Action的实现类
struts+hibernate+oracle+easyui实现lazyout组件的简单案例——Action的实现类
|
5月前
|
监控 Oracle 关系型数据库
"深度剖析:Oracle SGA大小调整策略——从组件解析到动态优化,打造高效数据库性能"
【8月更文挑战第9天】在Oracle数据库性能优化中,系统全局区(SGA)的大小调整至关重要。SGA作为一组共享内存区域,直接影响数据库处理能力和响应速度。本文通过问答形式介绍SGA调整策略:包括SGA的组成(如数据缓冲区、共享池等),如何根据负载与物理内存确定初始大小,手动调整SGA的方法(如使用`ALTER SYSTEM`命令),以及利用自动内存管理(AMM)特性实现智能调整。调整过程中需注意监控与测试,确保稳定性和性能。
416 2
|
7月前
|
Oracle Java 关系型数据库
[学习笔记] 在Eclipse中使用Hibernate,并创建第一个Demo工程,数据库为Oracle XE
[学习笔记] 在Eclipse中使用Hibernate,并创建第一个Demo工程,数据库为Oracle XE
|
8月前
|
SQL 缓存 Java
框架分析(9)-Hibernate
框架分析(9)-Hibernate
|
2月前
|
缓存 Java 数据库连接
Hibernate:Java持久层框架的高效应用
通过上述步骤,可以在Java项目中高效应用Hibernate框架,实现对关系数据库的透明持久化管理。Hibernate提供的强大功能和灵活配置,使得开发者能够专注于业务逻辑的实现,而不必过多关注底层数据库操作。
22 1
|
5月前
|
SQL Java 数据库连接
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。
Hibernate 是一款开源 ORM(对象关系映射)框架,封装了 JDBC,允许以面向对象的方式操作数据库,简化了数据访问层的开发。通过映射机制,它可以自动处理对象与数据库表之间的转换,支持主流数据库,提高了代码的可移植性和可维护性。其核心接口包括 SessionFactory、Session 和 Transaction 等,通过它们可以执行数据库的 CRUD 操作。配置方面,需在项目中引入 Hibernate 及数据库驱动依赖,并创建 `hibernate.cfg.xml` 配置文件来设置数据库连接和 Hibernate 行为参数。
69 1
|
5月前
|
数据库 Java 数据库连接
Struts 2 与 Hibernate 的完美邂逅:如何无缝集成两大框架,轻松玩转高效 CRUD 操作?
【8月更文挑战第31天】本文通过具体示例介绍了如何在 Struts 2 中整合 Hibernate,实现基本的 CRUD 操作。首先创建 Maven 项目并添加相关依赖,接着配置 Hibernate 并定义实体类及其映射文件。然后创建 DAO 接口及实现类处理数据库操作,再通过 Struts 2 的 Action 类处理用户请求。最后配置 `struts.xml` 文件并创建 JSP 页面展示用户列表及编辑表单。此示例展示了如何配置和使用这两个框架,使代码更加模块化和可维护。
171 0
|
6月前
|
SQL Java 数据库连接
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
Java面试题:简述ORM框架(如Hibernate、MyBatis)的工作原理及其优缺点。
94 0