j2ee之hibernate工具类

本文介绍了一个名为MyJdbcUtils的工具类,该工具类基于Hibernate框架,提供了包括数据保存、查询、分页等功能在内的多种数据库操作方法。通过这些方法,可以有效地简化Java应用程序与数据库交互的过程。
package com.newtouch.utils;

import org.hibernate.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.orm.hibernate4.support.HibernateDaoSupport;
import org.springframework.stereotype.Component;

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

/**
* 工具类实例化
*
* @author 邵欣
* @version 1.0
* @project_name Personnel_Management_System
* @package_name com.newtouch.utils
* @class_name MyJdbcUtils
* @company 新致软件
* @time 2017年9月2日 上午10:30:10
*/
@Component("myJdbcUtils")
public class MyJdbcUtils extends HibernateDaoSupport {
/**
* 属性
*
* @param sessionFactory void
* @author 邵欣
* @time 2017年9月2日上午10:30:25
*/
@Autowired
public void setSessionFactoryOverride(SessionFactory sessionFactory) {
super.setSessionFactory(sessionFactory);
}

/**
* 保存或者修改这个对象所包含的数据
*
* @param entity void
* @author 邵欣
* @time 2017年9月2日下午8:57:23
*/
public void saveOrUpdate(Object entity) {
Session session = null;
Transaction ts = null;
try {
session = this.getHibernateTemplate().getSessionFactory().openSession();
ts = session.beginTransaction();
session.saveOrUpdate(entity);
ts.commit();
} catch (Exception e) {
e.printStackTrace();
ts.rollback();
} finally {
session.close();
}
}

/**
* 查询一组数据
*
* @param sql
* @param obj
* @return List<?>
* @author 邵欣
* @time 2017年9月2日下午9:02:08
*/
@SuppressWarnings("unchecked")
public <T> List<T> find(String sql, Object... values) {
Session session = this.getHibernateTemplate().getSessionFactory().openSession();
Query queryObject = session.createQuery(sql);
if (values != null) {
for (int i = 0; i < values.length; i++) {
queryObject.setParameter(i, values[i]);
}
}
return queryObject.list();
}

/**
* 查找指定的一条数据
*
* @param sql
* @param obj
* @return T
* @author 邵欣
* @time 2017年9月2日下午9:14:59
*/
@SuppressWarnings("unchecked")
public <T> T findAEntity(String sql, Object... values) {
Session session = this.getHibernateTemplate().getSessionFactory().openSession();
Query queryObject = session.createQuery(sql);
if (values != null) {
for (int i = 0; i < values.length; i++) {
queryObject.setParameter(i, values[i]);
}
}
List<T> list = queryObject.list();
if (list.size() > 0) {
return (T) list.get(0);
} else {
System.out.println("数据库中没有这条数据");
return null;
}
}

/**
* 根据id查找对象
*
* @param clazz
* @param id
* @return T
* @author 邵欣
* @time 2017年9月2日下午9:14:22
*/
public <T> T get(Class<T> clazz, Serializable id) {
return this.getHibernateTemplate().get(clazz, id);
}

/**
* 分页查询的数据
*
* @param sql
* @param startNumber
* @param pageCount
* @return List<T>
* @author 邵欣
* @time 2017年9月2日下午9:41:03
*/
@SuppressWarnings("unchecked")
public <T> List<T> pageSelect(String sql, int startNumber, int pageCount) {
Session session = this.getHibernateTemplate().getSessionFactory().openSession();
Query query = session.createQuery(sql);
query.setFirstResult(startNumber);
query.setMaxResults(pageCount);
return query.list();
}

/**
* 分页查询的总行数
*
* @param sql
* @param startNumber
* @param pageCount
* @return int
* @author 邵欣
* @time 2017年9月2日下午9:40:49
*/
public int totalPageCount(String sql, int startNumber, int pageCount) {
Session session = this.getHibernateTemplate().getSessionFactory().openSession();
Query query = session.createQuery(sql);
ScrollableResults scroll = query.scroll();
scroll.last();
int totalCount = scroll.getRowNumber() + 1;
return totalCount;
}

/**
* 删除一条数据(不建议使用)
*
* @param object void
* @author 邵欣
* @time 2017年9月2日下午10:02:09
*/
public void delete(Object object) {
Session session = this.getHibernateTemplate().getSessionFactory().openSession();
Transaction tx = session.beginTransaction();
session.delete(object);
tx.commit();
session.close();
}


}

转载于:https://www.cnblogs.com/ShaoXin/p/7476844.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值