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

Hibernate 通用接口设计

阅读更多

 

public interface CommonMng {

    /**
     * 根据主键进行单个对象查询
     * 
     * @author guduxing890
     * @param clazz
     *            EntityClass
     * @param pk
     *            主键
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> T findEntityById(Class<T> clazz, Serializable pk);

    /**
     * 根据主键和 属性参数进行单个对象查询
     * 
     * @author guduxing890
     * @param clazz
     *            EntityClass
     * @param pk
     *            主键
     * @param properties
     *            属性
     * @param param
     *            参数
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> T findByProperty(Class<T> clazz, Serializable pk,
	    String properties, Object param);

    /**
     * 查询实体所有记录
     * 
     * @author guduxing890
     * @param clazz
     *            EntityClass
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> List<T> findByClass(Class<T> clazz);

    /**
     * 根据属性和参数,查询实体记录
     * 
     * @author guduxing890
     * @param clazz
     *            EntityClass
     * @param properties
     *            属性数组
     * @param params
     *            参数数组
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params);

    /**
     * 根据属性和参数, 查询实例记录,增加排序字段和排序方式 <br/>
     * 备注:如果排序字段和排序方式不对等,多余的排序字段自动使用 升序排列
     * 
     * @author guduxing890
     * @param clazz
     *            实体类
     * @param properties
     *            属性数组
     * @param params
     *            参数数组
     * @param orderProperty
     *            排序字段数组
     * @param sort
     *            排序方式
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params, String[] orderProperty, String[] sort);

    /**
     * 根据参数,查询数量
     * 
     * @author guduxing890
     * @param clazz
     * @param properties
     * @param params
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> int count(Class<T> clazz, String[] properties, Object[] params);

    /**
     * 根据属性和参数, 查询实例记录,增加排序字段和排序方式 ,和返回最大记录数<br/>
     * 备注:如果排序字段和排序方式不对等,多余的排序字段自动使用 升序排列
     * 
     * @author guduxing890
     * @param clazz
     *            实体类
     * @param properties
     *            属性
     * @param params
     *            参数
     * @param orderProperty
     *            排序字段
     * @param sort
     *            排序方式
     * @param count
     *            最大返回数量
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params, String[] orderProperty, String[] sort, int count);

    /**
     * 根据属性和参数, 查询分页,增加排序字段和排序方式 ,和返回最大记录数<br/>
     * 备注:如果排序字段和排序方式不对等,多余的排序字段自动使用 升序排列
     * 
     * @author guduxing890
     * @param clazz
     *            实体类
     * @param properties
     *            属性
     * @param params
     *            参数
     * @param orderProperty
     *            排序字段
     * @param sort
     *            排序方式
     * @param pageNo
     *            页码
     * @param count
     *            最大返回数量
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> Pagination<T> findPager(Class<T> clazz, String[] properties,
	    Object[] params, String[] orderProperty, String[] sort, int pageNo,
	    int count);

    /**
     * 根据条件查询对象
     * 
     * @author guduxing890
     * @param clazz
     *            实体类
     * @param properties
     *            属性
     * @param params
     *            参数
     * @param count
     *            最大返回数量
     * @return
     * @see [类、类#方法、类#成员]
     */
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params, int count);

    /**
     * 更新或修改对象
     * 
     * @author guduxing890
     * @param t
     *            实例对象
     * @see [类、类#方法、类#成员]
     */
    public <T> void saveOrUpdate(T t);

    /**
     * 新增对象
     * 
     * @author guduxing890
     * @param t
     *            实例对象
     * @see [类、类#方法、类#成员]
     */
    public <T> void save(T t);

    /**
     * 保存所有对象
     * 
     * @author guduxing890
     * @param t
     * @see [类、类#方法、类#成员]
     */
    <T> void saveAll(T... t);

    /**
     * 根据属性查询实体
     * 
     * @author guduxing890
     * @param clazz
     *            Hibernate映射实体
     * @param properties
     *            属性数组
     * @param params
     *            参数数组
     * @param orderProperty
     *            排序属性数组
     * @param sort
     *            排序方式
     * @param firstResult
     *            起始行
     * @param count
     *            最大返回结果数
     * @return
     * @see [类、类#方法、类#成员]
     */
    <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params, String[] orderProperty, String[] sort,
	    int firstResult, int count);

    /**
     * 删除对象
     * 
     * @author guduxing890
     * @param t
     * @see [类、类#方法、类#成员]
     */
    <T> void delete(T t);

 

 

 

以上为Services 层

 

 dao 层代码实现

 

/*
 * 文 件 名:  CommonDaoImpl.java
 * 版    权:  XX Technologies Co., Ltd. Copyright YYYY-YYYY,  All rights reserved
 * 描    述:  <描述>
 * 修 改 人:  guduxing890
 * 修改时间:  2013-3-22
 * 跟踪单号:  <跟踪单号>
 * 修改单号:  <修改单号>
 * 修改内容:  <修改内容>
 */
package com.xxx.web.dao.impl;

import java.io.Serializable;
import java.util.Collection;
import java.util.List;

import org.apache.commons.lang.StringUtils;
import org.hibernate.Criteria;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Projections;
import org.hibernate.criterion.Restrictions;
import org.springframework.stereotype.Repository;

import com.xxx.common.Constants;
import com.xxx.common.dao.HibernateSimpleDao;
import com.xxx.web.dao.CommonDao;
/**
 * 
 * @author guduxing890
 * @version [版本号, 2013-3-22]
 * @see [相关类/方法]
 * @since [产品/模块版本]
 */
@Repository
@SuppressWarnings("rawtypes")
public class CommonDaoImpl extends HibernateSimpleDao implements CommonDao {

    private static final String OBJECT_SEP = ".";

    /**
     * 重载方法
     * 
     * @param clazz
     * @param pk
     * @return
     */
    @SuppressWarnings("unchecked")
    @Override
    public <T> T getEntityById(Class<T> clazz, Serializable pk) {
	return (T) getSession().get(clazz, pk);
    }

    @SuppressWarnings("unchecked")
    @Override
    public <T> T findByProperty(Class<T> clazz, Serializable pk,
	    String properties, Object param) {
	Criteria criteria = getSession().createCriteria(clazz);
	criteria.add(Restrictions.eq(properties, param));
	criteria.add(Restrictions.idEq(pk));
	return (T) criteria.uniqueResult();
    }

    @Override
    public <T> List<T> findByClass(Class<T> clazz) {
	return findByProperties(clazz, null, null, null, null);
    }

    @Override
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params) {
	return findByProperties(clazz, properties, params, null, null);
    }

    @Override
    public <T> void saveOrUpdateAll(T... t) {
	for (T a : t) {
	    this.saveOrUpdate(a);
	}
    }

    /**
     * 重载方法
     * 
     * @param clazz
     * @param properties
     * @param params
     * @param orderProperty
     * @param sort
     * @param count
     * @return
     */
    @Override
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params, String[] orderProperty, String[] sort,
	    Integer count) {
	return this.findByProperties(clazz, properties, params, orderProperty,
		sort, null, count);

    }

    /**
     * 重载方法
     * 
     * @param clazz
     * @param properties
     * @param params
     * @return
     */
    @Override
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params, String[] orderProperty, String[] sort) {
	return findByProperties(clazz, properties, params, null, null, null);
    }

    /**
     * 保存对象
     * 
     * @author guduxing890
     * @param t
     * @see [类、类#方法、类#成员]
     */
    public <T> void save(T t) {
	if (t instanceof Collection) {
	    Collection c = (Collection) t;
	    this.getHibernateTemplate().saveOrUpdateAll(c);
	} else {
	    this.getSession().save(t);
	}
    }

    /**
     * 保存或更新对象
     * 
     * @author guduxing890
     * @param t
     * @see [类、类#方法、类#成员]
     */
    public <T> void saveOrUpdate(T t) {
	this.getSession().saveOrUpdate(t);
    }

    /**
     * 重载方法
     * 
     * @param clazz
     * @param properties
     * @param params
     * @return
     */
    @Override
    public <T> int count(Class<T> clazz, String[] properties, Object[] params) {

	Criteria criteria = getSession().createCriteria(clazz);
	if (null != properties) {
	    int paramLen = properties.length;
	    for (int i = 0; i < paramLen; i++) {
		// 进行属性处理
		String property = properties[i];

		// 把属性进行用 . 分割。 取出里面的每一个子对象。作为一个子 Criteria.进行关联查询
		if (property.indexOf(OBJECT_SEP) != -1) {
		    String[] props = StringUtils.split(property, OBJECT_SEP);

		    Criteria propertyCriteria = null;
		    for (int y = 0; y < props.length - 1; y++) {
			if (y == 0) {
			    propertyCriteria = criteria
				    .createCriteria(props[y]);
			} else {
			    propertyCriteria = propertyCriteria
				    .createCriteria(props[y]);
			}
		    }
		    propertyCriteria.add(Restrictions.eq(
			    props[props.length - 1], params[i]));
		} else {
		    criteria.add(Restrictions.eq(properties[i], params[i]));
		}

	    }
	}
	// 查询记录条数
	criteria.setProjection(Projections.rowCount());

	return Integer.parseInt(criteria.uniqueResult().toString());
    }

    /**
     * 重载方法
     * 
     * @param clazz
     * @param properties
     * @param params
     * @param orderProperty
     * @param sort
     * @param firstResult
     * @param count
     * @return
     */
    @SuppressWarnings("unchecked")
    @Override
    public <T> List<T> findByProperties(Class<T> clazz, String[] properties,
	    Object[] params, String[] orderProperty, String[] sort,
	    Integer firstResult, Integer count) {
	Criteria criteria = getSession().createCriteria(clazz);
	if (null != properties) {
	    int paramLen = properties.length;
	    for (int i = 0; i < paramLen; i++) {
		// 进行属性处理
		String property = properties[i];

		// 把属性进行用 . 分割。 取出里面的每一个子对象。作为一个子 Criteria.进行关联查询
		if (property.indexOf(OBJECT_SEP) != -1) {
		    String[] props = StringUtils.split(property, OBJECT_SEP);

		    Criteria propertyCriteria = null;
		    for (int y = 0; y < props.length - 1; y++) {
			if (y == 0) {
			    propertyCriteria = criteria
				    .createCriteria(props[y]);
			} else {
			    propertyCriteria = propertyCriteria
				    .createCriteria(props[y]);
			}
		    }
		    propertyCriteria.add(Restrictions.eq(
			    props[props.length - 1], params[i]));
		} else {
		    criteria.add(Restrictions.eq(properties[i], params[i]));
		}

	    }
	}
	// 增加排序字段
	if (null != orderProperty) {
	    int length = orderProperty.length;

	    for (int i = 0; i < length; i++) {
		Order order = null;
		if (null != sort && i < sort.length) {
		    order = Constants.SORT_TYPE_ASC.equalsIgnoreCase(sort[i]) ? Order
			    .asc(orderProperty[i]) : Order
			    .desc(orderProperty[i]);
		} else {
		    order = Order.asc(orderProperty[i]);
		}
		criteria.addOrder(order);

	    }
	}
	if (count == null) {
	    count = 5000;
	}
	if (null != firstResult) {
	    criteria.setFirstResult(firstResult);
	}
	criteria.setMaxResults(count);
	return (List<T>) criteria.list();
    }

    /**
     * 重载方法
     * 
     * @param t
     */
    @Override
    public <T> void delete(T t) {
	this.getSession().delete(t);
    }

}

 

 

分享到:
评论

相关推荐

    部门绩效考核评价表excel.xls

    部门绩效考核评价表excel

    全面的公司行政费用统计表.xls

    全面的公司行政费用统计表

    视觉跟踪算法综述.pdf

    视觉跟踪算法综述.pdf

    CMD 命令行高级教程精选合编

    CMD 命令行高级教程精选合编

    apr-devel-1.4.8-7.el7.x64-86.rpm.tar.gz

    1、文件内容:apr-devel-1.4.8-7.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/apr-devel-1.4.8-7.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装

    10-4-生产主管绩效考核表(自动计算、等级评价).xlsx

    10-4-生产主管绩效考核表(自动计算、等级评价)

    深度学习python基础(第三节) 函数、列表

    深度学习python基础(第三节) 函数、列表

    岗位绩效考核评定表excel表格模板.xlsx

    岗位绩效考核评定表excel表格模板

    成品库仓管员绩效考核表.xls

    成品库仓管员绩效考核表

    环卫业务 基础知识培训(小步创想)PPT(133页).pptx

    一、智慧环卫管理平台的建设背景与目标 智慧环卫管理平台的建设源于对环卫管理全面升级的需求。当前,城管局已拥有139辆配备车载GPS系统、摄像头和油耗传感器的环卫车辆,但环卫人员尚未配备智能移动终端,公厕也缺乏信息化系统和智能终端设备。为了提升环卫作业效率、实现精细化管理并节省开支,智慧环卫管理平台应运而生。该平台旨在通过信息化技术和软硬件设备,如车载智能终端和环卫手机App,实时了解环卫人员、车辆的工作状态、信息和历史记录,使环卫作业管理透明化、精细化。同时,平台还期望通过数据模型搭建和数据研读,实现更合理的环卫动态资源配置,为环卫工作的科学、健康、持续发展提供决策支持。 二、智慧环卫管理平台的建设内容与功能 智慧环卫管理平台的建设内容包括运行机制体制建设、业务流程设计、智慧公厕系统建设、网络建设、主机和储存平台需求、平台运维管理体系、硬件标准规范体系以及考核评价体系等多个方面。其中,智慧公厕系统建设尤为关键,它能实时监控公厕运行状态,保障公厕的清洁和正常运行。平台建设还充分利用了现有的电子政务网络资源,并考虑了有线和无线网络的需求。在功能上,平台通过普查、整合等手段全面收集环卫车辆、企业、人员、设施、设备等数据,建立智慧环卫基础数据库。利用智能传感、卫星定位等技术实现环卫作业的在线监管和远程监控,实现对道路、公共场所等的作业状况和卫生状况的全面监管。此外,平台还建立了环卫作业网格化管理责任机制,实现从作业过程到结果的全面监管,科学评价区域、部门、单位和人员的作业效果。 三、智慧环卫管理平台的效益与风险规避 智慧环卫管理平台的建设将带来显著的环境、经济和管理效益。环境方面,它将有力推进环境卫生监管服务工作,改善环境卫生状况,为人民群众创造更加清洁、卫生的工作和生活环境。经济方面,通过智慧化监管,大大降低了传统管理手段的成本,提高了监管的准确性和效率。管理方面,平台能够追踪溯源市民反映的问题,如公厕异味、渣土车辆抛洒等,并找到相应的责任单位进行处置,防止类似事件再次发生。同时,平台还拥有强大的预警机制功能,能够在很多环卫问题尚未出现前进行处置。然而,平台建设也面临一定的风险,如部门协调、配合问题,建设单位选择风险以及不可预测的自然灾害等。为了规避这些风险,需要加强领导、统一思想,选择优秀的系统集成商承接项目建设,并做好计算机和应用系统的培训工作。同时,也要注意标准制定工作和相关法律法规的制定工作,以保证系统建设完成后能够真正为环卫管理工作带来便利。

    基于平衡计分卡绩效考核表(管理高层)模板.xls

    基于平衡计分卡绩效考核表(管理高层)模板

    网站运营各部门绩效考核表.xls

    网站运营各部门绩效考核表

    XX公司行政部绩效考核指标.xls

    XX公司行政部绩效考核指标

    基于齿向修形的抛物线锥齿轮仿真分析.pdf

    基于齿向修形的抛物线锥齿轮仿真分析.pdf

    三相半桥逆变器低电压穿越控制策略设计:两级式光伏并网系统电路原理与容量优化报告,两级式光伏并网系统及其低电压穿越控制策略设计,容量30kW 三相半桥逆变器,boost电路作前级 带低电压穿越,有一

    三相半桥逆变器低电压穿越控制策略设计:两级式光伏并网系统电路原理与容量优化报告,两级式光伏并网系统及其低电压穿越控制策略设计,容量30kW。 三相半桥逆变器,boost电路作前级。 带低电压穿越,有一万七千字的报告,没有水文字。 报告内容,电路原理,pi参数设计,bode和根轨迹分析,波形良好 ,关键词:两级式光伏并网系统;低电压穿越控制策略;30kW容量;三相半桥逆变器;boost电路;前级设计;低电压穿越功能;报告内容;电路原理;PI参数设计;Bode和根轨迹分析;波形良好。,基于30kW容量两级式光伏并网系统的控制策略设计:低电压穿越及高效逆变技术研究

    毕业设计文本预测项目python源码+托尔斯泰《战争与和平》文本分析数据集-最新出炉.zip

    毕业设计文本预测项目python源码+托尔斯泰《战争与和平》文本分析数据集-最新出炉 关于数据集 背景: 该数据集包含列夫·托尔斯泰的《战争与和平》的全文,这是一部于 1869 年出版的开创性文学作品。作为公共领域文本,它为对文学分析、自然语言处理和历史研究感兴趣的研究人员和爱好者提供了丰富的资源。这部小说以俄国拿破仑战争为背景,探讨了战争、和平和人类状况的主题。 内容: 数据集由一个纯文本文件组成,其中包含《战争与和平》的完整叙述。文本已进行预处理,以方便分析和建模,使其适用于各种应用,包括文本挖掘、情感分析和机器学习项目。该文件可通过以下链接访问:战争与和平文本数据集。

    18 -广告部经理绩效考核表1.xlsx

    18 -广告部经理绩效考核表1

    永磁同步电机电流内环PR控制Simulink仿真模型:转速电流双闭环矢量控制,波形完美带原理说明与文献参考,永磁同步电机电流内环PR控制Matlab simulink仿真模型,参数已设置好,可直接运行

    永磁同步电机电流内环PR控制Simulink仿真模型:转速电流双闭环矢量控制,波形完美带原理说明与文献参考,永磁同步电机电流内环PR控制Matlab simulink仿真模型,参数已设置好,可直接运行。 属于PMSM转速电流双闭环矢量控制系统模型。 电流内环采用PR控制器,不需要旋转坐标变,在静止坐标下进行矢量控制,转速外环采用PI控制器。 波形完美,包含原理说明文档和参考文献。 ,关键词:永磁同步电机;电流内环PR控制;Matlab simulink仿真模型;PMSM转速电流双闭环矢量控制系统;PR控制器;PI控制器;波形完美;原理说明文档;参考文献。,"基于PR控制的永磁同步电机电流内环仿真模型:静止坐标矢量控制与波形解析"

    基于主从博弈理论的共享储能与综合能源微网优化运行策略研究:Stackelberg均衡下的优化调度与运行框架,基于主从博弈理论的共享储能与综合能源微网优化运行研究 关键词:主从博弈 共享储能 综合能源微

    基于主从博弈理论的共享储能与综合能源微网优化运行策略研究:Stackelberg均衡下的优化调度与运行框架,基于主从博弈理论的共享储能与综合能源微网优化运行研究 关键词:主从博弈 共享储能 综合能源微网 优化调度 参考文档:《基于主从博弈理论的共享储能与综合能源微网优化运行研究》完全复现 仿真平台:MATLAB yalmip+cplex 主要内容:代码主要做的是基于主从博弈理论的共享储能与综合能源微网优化运行研究,首先介绍了系统运行框架,分析了系统内各利益体的功能。 其次,分别针对微网运营商、共享储能服务商以及用户聚合商建立优化运行模型。 进一步,分析了微网运营商与用户聚合商间的博弈关系,提出共享储能背景下微网运营商与用户聚合商间的 Stackelberg 博弈模型,并证明Stackelberg 均衡解的存在性与唯一性。 最后,在 MATLAB平台上进行算例仿真,通过 Yalmip 工具与 CPLEX 求解器进行建模与求解,利用启发式算法与求解器相结合的方法优化微网运营商与用户聚合商的策略。 结果表明,本文所提模型所提模型不仅能有效权衡微网运营商与用户聚合商的利益,也实现了用户聚合商

Global site tag (gtag.js) - Google Analytics