@Repository
@Transactional
public class BaseDaoImpl<T, ID extends Serializable, DaoImpl extends BaseDaoImpl<T, String, DaoImpl>>
extends HibernateDaoSupport implements IBaseDAO<T, String> {
@SuppressWarnings("unchecked")
private static final Class T = null;
public List<T> findObject(String querySql, Object[] values)
throws DataAccessException, SQLException {
return lReturnSure(super.getHibernateTemplate().find(querySql, values));
}
public List<T> findObject(String querySql, Object value)
throws DataAccessException, SQLException {
return lReturnSure(super.getHibernateTemplate().find(querySql, value));
}
public List<T> findObject(String querySql) throws DataAccessException,
SQLException {
return lReturnSure(super.getHibernateTemplate().find(querySql));
}
public List<T> lReturnSure(List<T> l) {
if (!l.isEmpty() && l.size() > 0)
return l;
else
return null;
}
public T oReturnSure(T t) {
if (t != null)
return t;
else
return null;
}
public T findObject(Integer objectId) throws DataAccessException,
SQLException {
return (T) this.getHibernateTemplate().load(T, objectId);
}
public T loadObject(String objectId) throws DataAccessException,
SQLException {
return oReturnSure((T) super.getHibernateTemplate().get(T, objectId));
}
/**===================================================
* T loadObject(Integer objectId) throws DataAccessException, SQLException
* ===================================================
*/
@SuppressWarnings("unchecked")
public T loadObject(Integer objectId) throws DataAccessException,
SQLException {
return oReturnSure((T) super.getHibernateTemplate().get(T, objectId));
}
@SuppressWarnings("unchecked")
public List<T> findObjectByLimit(Map<String, String> condition,
final int firstResult,final int maxResult,Map<String, String> orderByMap) throws DataAccessException,
SQLException {
StringBuffer sb = new StringBuffer(" from " + T + " as model ");
if (condition != null)
{
Set keySet = condition.keySet();
for (Iterator iterator = keySet.iterator(); iterator.hasNext();)
{
Object object = (Object) iterator.next();
sb.append(" and model." + object + "=" + condition.get(object));
}
}
if (orderByMap != null)
{
Set keySet = orderByMap.keySet();
for (Iterator iterator = keySet.iterator(); iterator.hasNext();)
{
String str = (String) iterator.next();
sb.append(" order by model." + str + " " + orderByMap.get(str));
}
}
return getResult(sb.toString(), firstResult, maxResult);
}
/**===================================================
* T getObject(String objectId) throws DataAccessException, SQLException
* ===================================================
*/
@SuppressWarnings("unchecked")
public T getObject(String objectId) throws DataAccessException,
SQLException {
return oReturnSure((T) super.getHibernateTemplate().get(T, objectId));
}
public List<T> findObjectByLimit(Map<String, String> condition,
int firstResult, int maxResult) throws DataAccessException,
SQLException {
StringBuffer sb = new StringBuffer(" from " + T + " as model ");
if (condition != null) {
Set keySet = condition.keySet();
for (Iterator iterator = keySet.iterator(); iterator.hasNext();) {
Object object = (Object) iterator.next();
sb.append(" and model." + object + "=" + condition.get(object));
}
}
return getResult(sb.toString(), firstResult, maxResult);
}
}
分享到:
相关推荐
需要注意的是,如果你只需要重新编译DevExpress.Persistent.BaseImpl程序集(请参考eXpressAppFramework-MediumTrustSupport文章),请按照“How to:Recompile the DevExpress.Persistent.BaseImpl.dll Assembly”...
而`BaseImpl.java`和`ServiceImpl.java`可能分别对应这些Dao接口的实现类,其中`BaseImpl.java`提供了一些基本的数据库操作方法,而`ServiceImpl.java`是业务服务接口的实现,将这些数据库操作封装成更符合业务逻辑...
自动委托 Java注释处理器,用于将接口API自动委派给该接口的组合实例。 该项目的灵感来自Google的项目,并利用了公开的实用程序。...}public final class BaseImpl implements Base { private final int x; public B
kotlin 委托 委托模式是软件设计模式中的一项基本技巧。在委托模式中,有两个对象参与处理同一个请求,接受请求的对象将请求委托给另一个对象来处理。 Kotlin 直接支持委托模式,更加优雅,简洁...class BaseImpl(val x
基于改进YOLOv5s的森林烟火检测算法.pdf
人力资源管理工具绩效考核excel模板01
施工班组长绩效考核表
57 -营业部经理绩效考核表1
XX公司行政部绩效考核指标
1、文件内容:ant-apache-xalan2-1.9.4-2.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/ant-apache-xalan2-1.9.4-2.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
部门绩效考核表模板(基于KPI以月度为例2)
11-6-质检员绩效考核表(含自动计算、等级评价及任意设置等级)
2024最新全国河流湖泊矢量数据 【数据介绍】 2024年中国河流湖泊数据 一份包含中国境内所有主要河流和湖泊的地理信息数据。 数据格式:Shapefile:广泛使用的GIS数据格式,方便在各类GIS软件中使用。 数据获取:访问OpenStreetMap官网,通过导出工具选择中国区域并下载所需的数据。 使用Geofabrik等第三方网站,可以下载预处理好的中国区域的OSM数据。 数据使用:GIS软件:如QGIS、ArcGIS等,用户可以在这些软件中导入OSM数据进行可视化、分析和编辑。 数据应用: 环境研究:分析河流湖泊的水质变化,研究水资源分布及其环境影响。 城市规划:用于规划城市水系、洪水防控、水资源管理等。 导航和旅游:为河流湖泊的导航和旅游路线规划提供数据支持。 科研:为水文地理研究、生态保护、气候变化等领域提供基础数据。 数据特点: 实时更新:OSM数据由全球用户贡献,具有较高的实时性和更新频率。 开放性:所有数据都在开放许可下发布,允许用户自由使用、修改和分发。 详细性:由于全球志愿者的不断努力,数据细节较为丰富,涵盖了从主要河流湖泊到小型水体的广泛范围。 数据时间2024年5月,shp格式,数据来源OpenStreetMap。 OpenStreetMap(OSM)介绍: 一个开放的、免费的、全球性的地图项目,由全球的志愿者和地图爱好者们共同创建和维护。 OSM的数据包括道路、建筑、公园、河流、湖泊等各类地理信息。由于是由众多志愿者共同编辑,OSM的数据具有很高的实时性和详细程度,特别是在一些活跃的区域,地图数据的更新速度和精度往往超过商业地图服务。 用户可以直接在OSM官网下载地图数据,数据格式主要有OSM XML和PBF等。此外,还有一些第三方网站和工具提供更加便捷的数据下载和处理服务,如Geofabrik、Overpass API等。 OSM的数据可以在各种GIS软件中使用,如QGIS、ArcGIS等。此外,还可以使用Python的OSMnx、GeoPandas等库进行编程处理,或者通过Leaflet、Mapbox等JavaScript库将OSM数据集成到web地图应用中。 OSM的所有数据都在开放许可下发布,允许用户自由使用、修改和分发。这使得OSM成为了许多公共项目、研究机构和商业公司的重要数据来源。
部门绩效考核评分表
12-11-运输车队长绩效考核表(含自动计算、等级评价)
1、文件内容:ant-javadoc-1.9.4-2.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/ant-javadoc-1.9.4-2.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
springboot整合 freemarker方法
1、文件内容:apache-commons-codec-1.8-7.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/apache-commons-codec-1.8-7.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
《旅游抽样调查资料》是反映入境游客在华(内地)花费和国内居民国内旅游情况的资料性年刊,分为上下两篇。 上篇为在华(内地)停留时间在3个月以内的入境游客抽样调查资料,由综合分析报告和调查分类数据两部分组成,分类数据包括:入境游客的主要特征,入境外国人、港澳台同胞的花费水平和花费构成、在境内的停留时间以及入境次数、流向和对住宿单位的选择等。 下篇为国内旅游抽样调查资料,汇集了对城镇居民和农村居民的国内旅游抽样调查结果,共分为四个部分:第一部分为综合分析报告;第二部分为国内旅游出游及花费情况;第三部分为城镇居民国内旅游抽样调查分类数据;第四部分为农村居民国内旅游抽样调查分类数据。
1、表单界面,身份证信息保存在dbf表中,供vfp应用使用,可导出为xls电子表格。 2、提供了身份证过期校验和查询功能。