HibernateUtil自己写的一个CRUD的工具类

解释下:

大侠们不要见怪,我在这里写的这个工具类肯定有很多不好的地方,我想的是在这里写个文章,好利用它的电子书功能来做个读书笔记。多多包含!

利用MyEclipse7.0自动生成的HibernateSessionFactory.java

 

 

HibernateUtil.java :

package com.cracker;

import java.util.ArrayList;
import org.hibernate.Criteria;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.criterion.Restrictions;

public class HibernateUtil {
	/**
	 * 保存
	 */
	public static void add(Object obj){
		Transaction st = null;
		Session session = null;
		try{
		session = HibernateSessionFactory.getSession();
		st = session.beginTransaction();
		session.save(obj);
		st.commit();
		}catch(HibernateException e){
			st.rollback();
			throw e;
		}finally{
			if(session!=null){
				if(session.isOpen()){
				session.close();
				}
			}
		}
	}
	/**
	 * 更新
	 */
	public static void update(Object obj){
		Transaction st = null;
		Session session = null;
		try{
		session = HibernateSessionFactory.getSession();
		st = session.beginTransaction();
		session.update(obj);
		st.commit();
		}catch(HibernateException e){
			st.rollback();
			throw e;
		}finally{
			if(session!=null){
				if(session.isOpen()){
				session.close();
				}
			}
		}
	}
	/**
	 * 删除
	 */
	public static void delete(Object obj){
		
		Session session = HibernateSessionFactory.getSession();
		try{
			
		session.delete(obj);
	
		} catch(HibernateException e){
			System.out.println("删除异常");
			throw e;
		}finally{
			if(session!=null){
				if(session.isOpen()){
				session.close();
				}
			}
		}
			
	}
	
	/**
	 * 查询ByID
	 */
	public static User queryById(int id){
		
		Session session = HibernateSessionFactory.getSession();
		User user = null;
		try{
		
			 user = (User)session.get(User.class,1);
		}catch (HibernateException e){
			System.out.println("查询ByID异常");
			throw e;
		}finally{
			if(session!=null){
				if(session.isOpen()){
				session.close();
				}
			}
		}
		return user;
	}
	
	/**
	 * Query By Name
	 */
	@SuppressWarnings("unchecked")
	public static ArrayList<User> queryByName(String name){
		ArrayList<User> userList = new ArrayList<User>();
		String hql = "from User as user where user.name=:name";
		Session session = HibernateSessionFactory.getSession();
		try{

			Query query =session.createQuery(hql);
//          分页显示
			query.setFirstResult(0);
			query.setMaxResults(4);
			query.setString("name", name);
//			快速获得hql的集合,不用像JDBC那样去一个一个取了
			userList = (ArrayList<User>) query.list();
		}catch(HibernateException e){
			System.out.println("QueryByName异常");
			throw e;
		}finally{
			if(session!=null){
				if(session.isOpen()){
				session.close();
				}
			}
		}
		return userList;
	}
	/**
	 * 
	 * 通过密码来查询,演示采用criteria方式
	 */
	@SuppressWarnings("unchecked")
	public static ArrayList<User> queryByPassword(String password){
		ArrayList<User> userList = new ArrayList<User>();
		Session session = HibernateSessionFactory.getSession();
		try{
			Criteria c = session.createCriteria(User.class);
//          分页显示
			c.setFirstResult(0);
			c.setMaxResults(4);
			c.add(Restrictions.eq("password", password));
//			快速获得的集合,不用想JDBC那样去一个一个取了
			userList = (ArrayList<User>) c.list();
		}catch(HibernateException e){
			System.out.println("QueryByName异常");
			throw e;
		}finally{
			if(session!=null){
				if(session.isOpen()){
				session.close();
				}
			}
		}
		return userList;
	}

}

 

你可能感兴趣的:(C++,c,Hibernate,C#,读书)