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是用于获取数据库信息的公共访问类 有了它,数据增删改查将会更加方便
ssh通用泛型DAO 共包含3个类:BaseHibernateDAO,Page,QueryParameter
基于matlab实现实现了基于项目的协同过滤代码,MATLAB实现.rar
数据来源:中国劳动统计NJ-2023版
企业固定资产信息管理系统设计与实现.doc
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。
【作品名称】:基于VB实现的学生成绩管理系统(源代码+系统+开题报告+答辩PPT) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。
银行信贷管理系统设计与实现-(毕业设计)1.docx
【作品名称】:基于VB实现的银行代扣代发工资系统(源代码+系统+开题报告) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。
数据来源:中国人口与就业统计NJ-2023版
java,大学课后作业
数据来源:中国电力统计NJ-2021版
【作品名称】:基于VB实现的网上餐饮管理系统设计(论文+源代码+开题报告+英文文献) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。
基于matlab实现烟花算法进行函数最小_最大值寻优,对十多个测试函数进行了寻优,效果良好,代码附带详细说明.rar
数据来源:中国电力统计NJ-2021版
【作品名称】:基于VB实现的商场管理系统设计(源代码+系统) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。
数据来源:中国劳动统计NJ-2023版
数据来源:中国电力统计NJ-2021版