亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? basedao.java

?? 采用最新Struts2+Hibernate架構開發
?? JAVA
字號:
package www.hibernate.util.method;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
import java.util.TreeSet;

import org.apache.commons.beanutils.BeanUtils;
import org.hibernate.Hibernate;
import org.hibernate.Query;
import org.hibernate.Session;


public class BaseDao {

	public BaseDao() {

	}

	/**
	 * open session method
	 * 
	 * @return sesion
	 */
	public Session openSession() {
		return Hibernate_util.openSession();
	}

	/**
	 * start Transaction method
	 * 
	 */
	public void beginTransaction() {
		Hibernate_util.beginTransaction();
	}

	/**
	 * commit Transaction method
	 * 
	 */
	public void commitTransaction() {
		Hibernate_util.commitTransaction();
	}

	/**
	 * rollback Transaction method
	 * 
	 */
	public void rollbackTransaction() {
		Hibernate_util.rollbackTransaction();
	}

	/**
	 * close Session method
	 * 
	 */
	public void closeSession() {
		Hibernate_util.closeSession();
	}

	/**
	 * save one object method
	 * 
	 * @param obj
	 * @return Serializable
	 */
	public synchronized java.io.Serializable save(Object obj) {
		java.io.Serializable id = null;
		try {
			// 調用 openSession() 方法 得到 session
			Session session = this.openSession();
			// 開始事務
			this.beginTransaction();
			id = session.save(obj);
			// 提交事務
			this.commitTransaction();
		} catch (Exception e) {
			// 事務回滾
			this.rollbackTransaction();
			e.printStackTrace();
		} finally {
			// 關閉session 資源
			this.closeSession();
		}
		return id;
	}

	/**
	 * persist one obj method
	 * 
	 * @param obj
	 */
	public synchronized void persist(Object obj) {
		try {
			Session session = this.openSession();
			this.beginTransaction();
			session.persist(obj);
			this.commitTransaction();
		} catch (Exception e) {
			this.rollbackTransaction();
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
	}

	/**
	 * update one object method
	 * 
	 * @param obj
	 */
	public synchronized void update(Object obj) {
		try {
			Session session = this.openSession();
			this.beginTransaction();
			session.update(obj);
			this.commitTransaction();
		} catch (Exception e) {
			this.rollbackTransaction();
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
	}

	/**
	 * commonality method
	 * 
	 * @param query
	 * @param param
	 */
	public void common(Query query, String[] param) {
		if (param != null && param.length > 0)
			for (int i = 0; i < param.length; i++) {
				query.setString(i, param[i]);
			}
	}

	/**
	 * update or delete method
	 * 
	 * @param hql
	 * @param param
	 */
	public synchronized void updateOrDelete(String hql, String[] param) {
		try {
			Session session = this.openSession();
			this.beginTransaction();
			Query query = session.createQuery(hql);
			// 調用common()方法,完成所傳字符串數組(String[])在該方法query下的賦值作業
			this.common(query, param);
			query.executeUpdate();
			this.commitTransaction();
		} catch (Exception e) {
			this.rollbackTransaction();
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
	}

	/**
	 * save or update method
	 * 
	 * @param obj
	 */
	public synchronized void saveOrUpdate(Object obj) {
		try {
			Session session = this.openSession();
			this.beginTransaction();
			session.saveOrUpdate(obj);
			this.commitTransaction();
		} catch (Exception e) {
			this.rollbackTransaction();
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
	}

	/**
	 * delete method
	 * 
	 * @param obj
	 */
	public synchronized void delete(Object obj) {
		try {
			Session session = this.openSession();
			this.beginTransaction();
			session.delete(obj);
			this.commitTransaction();
		} catch (Exception e) {
			this.rollbackTransaction();
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
	}

	/**
	 * query method
	 * 
	 * @param hql
	 * @param param
	 * @return list
	 */
	public synchronized List query(String hql, String[] param) {
		List list = null;
		try {
			Session session = this.openSession();
			Query query = session.createQuery(hql);
			// 調用common()方法,完成所傳字符串數組(String[])在該方法query下的賦值作業
			this.common(query, param);
			list = query.list();
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
		return list;
	}

	/**
	 * query method
	 * 
	 * @param hql
	 * @param param
	 * @param curpage
	 * @param page_record
	 * @return list
	 */
	public synchronized List query(String hql, String[] param, int curpage,
			int page_record) {
		List list = null;
		try {
			Session session = this.openSession();
			Query query = session.createQuery(hql);
			// 調用common()方法,完成所傳字符串數組(String[])在該方法query下的賦值作業
			this.common(query, param);
			// 實現分頁的起始位置
			query.setFirstResult((curpage - 1) * page_record);
			// 實現分頁單位(每頁所顯示最大記錄數)
			query.setMaxResults(page_record);
			list = query.list();
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
		return list;
	}

	/**
	 * query method Class joclass 為vo ,即為查詢多表,而只要求返回特定字段而設置的一個vo 此方法需要用到
	 * apache的產品 ,把下面三個jar文件放到lib下即可 commons-beanutils-bean-collecions.jar
	 * commons-beanutils-beanutils-core.jar commons-beanutils.jar
	 * 
	 * @param hql
	 * @param param
	 * @param curpage
	 * @param page_record
	 * @param joclass
	 * @return list
	 */
	public synchronized List query(String hql, String[] param, int curpage,
			int page_record, Class joclass) {
		List beans = new ArrayList();// 聲明本方法所要返回的數組
		Session session = this.openSession();
		Query query = session.createQuery(hql);
		// 調用common()方法,完成所傳字符串數組(String[])在該方法query下的賦值作業
		this.common(query, param);
		// 實現分頁的起始位置
		query.setFirstResult((curpage - 1) * page_record);
		// 實現分頁單位(每頁所顯示最大記錄數)
		query.setMaxResults(page_record);
		try {
			List<Object[]> object = query.list();
			if (object != null)
				for (int i = 0; i < object.size(); i++){
					Object jo = joclass.newInstance();
					Object[] one = object.get(i);
					for (Object obj : one) {
						// obj對象中如果有jo對象的
						BeanUtils.copyProperties(jo, obj);
					}
					beans.add(jo);
				}
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
		return beans;
	}

	/**
	 * converge function method
	 * 
	 * @param hql
	 * @param param
	 * @return int
	 */
	public int getValue(String hql, String[] param) {
		int id = 0;
		try {
			Session session = this.openSession();
			Query query = session.createQuery(hql);
			this.common(query, param);
			List<Integer> list = query.list();
			id = list.get(0);
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
		return id;
	}

	/**
	 * get method query one record
	 * 
	 * @param clazz
	 * @param id
	 * @return object
	 */
	public synchronized Object get(Class clazz, Serializable id) {
		Object obj = null;
		try {
			Session session = this.openSession();
			obj = session.get(clazz, id);
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
		return obj;
	}

	/**
	 * load method query one record
	 * 
	 * @param clazz
	 * @param id
	 * @return object
	 */
	public synchronized Object load(Class clazz, Serializable id) {
		Object one = null;
		try {
			Session session = this.openSession();
			one = session.load(clazz, id);
			Hibernate.initialize(one);
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
		return one;
	}
	
	public synchronized Set copyProperty(String hql, String[] param, Class joclass) {
		Set beans = new TreeSet();// 聲明本方法所要返回的數組
		Session session = this.openSession();
		Query query = session.createQuery(hql);
		// 調用common()方法,完成所傳字符串數組(String[])在該方法query下的賦值作業
		this.common(query, param);
		try {
			List<Object[]> object = query.list();
			if (object != null)
				for (int i = 0; i < object.size(); i++){
					Object jo = joclass.newInstance();
					Object[] one = object.get(i);
					for (Object obj : one) {
						// obj對象中如果有jo對象的
						BeanUtils.copyProperties(jo, obj);
					}
					beans.add(jo);
				}
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			this.closeSession();
		}
		return beans;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久精品tv| 在线一区二区三区四区| 欧美一区二区女人| 久久精品免费观看| 国产清纯美女被跳蛋高潮一区二区久久w | 波多野洁衣一区| 亚洲亚洲精品在线观看| 欧美一区二区三区影视| 欧美日韩视频一区二区| 激情五月婷婷综合网| 亚洲精品国产精品乱码不99| 91精品国产91综合久久蜜臀| 色av成人天堂桃色av| av中文字幕不卡| 欧美性视频一区二区三区| 国产一区欧美一区| 亚洲一区二区综合| 久久精品亚洲乱码伦伦中文| 欧美特级限制片免费在线观看| 色综合久久99| 国产91高潮流白浆在线麻豆| 亚洲成人免费在线| 亚洲视频在线一区二区| 2022国产精品视频| 欧美精品aⅴ在线视频| fc2成人免费人成在线观看播放| 99视频一区二区三区| 欧美日韩亚洲另类| 欧美成人a∨高清免费观看| 欧美日韩在线不卡| 26uuu国产日韩综合| 欧美韩国日本不卡| 欧美—级在线免费片| 亚洲欧洲综合另类| 成人免费一区二区三区视频| 久久久久久久久久久黄色| 国产精品久久一卡二卡| 国产亚洲婷婷免费| 欧美激情一区二区三区全黄 | 一区二区三区小说| 国产精品进线69影院| 亚洲一线二线三线久久久| 日本不卡在线视频| 亚洲国产精品久久不卡毛片| 久久er99热精品一区二区| 成人午夜大片免费观看| 粉嫩av亚洲一区二区图片| 欧美影院一区二区三区| www成人在线观看| 亚洲一区二区三区美女| 国产一区二区三区国产| 精品视频999| 亚洲欧美怡红院| 国产在线精品一区二区 | 亚洲一区影音先锋| 国产成人在线视频网站| 国产精品资源站在线| 国产精品888| 91精品国产免费久久综合| 亚洲图片欧美激情| 国产一区二区三区高清播放| 欧美日韩久久久久久| 欧美成人a∨高清免费观看| 亚洲精品你懂的| 成人短视频下载| 在线亚洲精品福利网址导航| 欧美日韩国产高清一区二区| 国产精品不卡一区| 另类的小说在线视频另类成人小视频在线 | 欧美日韩三级一区| 欧美视频一区二区三区| 成人午夜视频免费看| 91网站最新地址| 国产亚洲一区字幕| 免费在线视频一区| 成人午夜私人影院| 久久久国产午夜精品| 日日夜夜精品视频免费| 国产盗摄一区二区| 精品国产免费人成在线观看| 国产精品久久综合| 懂色一区二区三区免费观看| 久久亚洲一级片| 久久99久久精品欧美| 成人精品视频.| 亚洲国产高清在线观看视频| 国产精品亚洲一区二区三区妖精| 欧美成人bangbros| 亚洲一级片在线观看| 欧美在线免费观看视频| 亚洲精品福利视频网站| 色综合久久久久久久久| 亚洲桃色在线一区| 在线亚洲高清视频| 天堂在线一区二区| 91免费视频网址| 亚洲国产成人高清精品| 欧美亚洲国产一区二区三区va| 亚洲线精品一区二区三区| 欧美三级中文字幕| 亚洲成a人v欧美综合天堂下载 | 成人h版在线观看| 欧美激情综合五月色丁香小说| av一区二区三区黑人| 亚洲精品欧美二区三区中文字幕| 在线看一区二区| 久久综合综合久久综合| 国产精品久久久久久久久搜平片| 色狠狠桃花综合| 免费人成精品欧美精品| 久久九九久精品国产免费直播| 粉嫩一区二区三区在线看| 亚洲国产精品麻豆| 久久亚洲综合色一区二区三区 | 午夜电影一区二区三区| 成人综合在线视频| 亚洲www啪成人一区二区麻豆| 精品日韩一区二区三区免费视频| 丰满岳乱妇一区二区三区| 亚洲激情网站免费观看| 欧美成人猛片aaaaaaa| 91免费在线看| 国产精品99久久久久久似苏梦涵| 一区二区三区免费看视频| 精品国产a毛片| 一本久道中文字幕精品亚洲嫩| 日韩不卡一区二区| 亚洲日本一区二区三区| 精品欧美乱码久久久久久1区2区| 色婷婷综合中文久久一本| 国内精品写真在线观看| 香蕉久久一区二区不卡无毒影院| 国产欧美日韩亚州综合| 在线不卡一区二区| 成人福利视频在线| 福利一区在线观看| 久久99国内精品| 亚洲成人av一区| 亚洲精品精品亚洲| 国产精品久久久久久久午夜片| 精品久久国产字幕高潮| 欧美日韩国产首页在线观看| 97se亚洲国产综合自在线观| 亚洲精品v日韩精品| 久久久99精品久久| 精品嫩草影院久久| 欧美日韩国产综合一区二区| 99精品欧美一区| 懂色av一区二区夜夜嗨| 激情久久五月天| 美国十次综合导航| 中文字幕日本乱码精品影院| 欧美夫妻性生活| 欧美日韩精品一区二区三区四区| 欧洲精品在线观看| 欧美性猛交一区二区三区精品| 在线视频一区二区三区| 色婷婷久久久综合中文字幕| 色婷婷av一区| 欧美日韩国产一区二区三区地区| 欧美午夜精品一区二区三区| 欧美在线综合视频| 欧美二区乱c少妇| 欧美第一区第二区| 日本高清不卡一区| 在线精品亚洲一区二区不卡| 欧美体内she精视频| 欧美一级生活片| 26uuu国产电影一区二区| 亚洲国产精品精华液ab| 中文字幕综合网| 一区二区三区日韩| 一区二区三区.www| 午夜精品一区二区三区电影天堂 | 欧美一二三四在线| 开心九九激情九九欧美日韩精美视频电影| 中文字幕巨乱亚洲| 国产亚洲欧美激情| 亚洲美女视频在线| 国产精品二三区| 国产精品二区一区二区aⅴ污介绍| 中文一区在线播放| 国产亚洲制服色| 久久久久国产免费免费| 日本va欧美va欧美va精品| 国产激情视频一区二区三区欧美| 偷拍一区二区三区四区| 亚洲一区二区三区四区在线 | 99国产欧美另类久久久精品| 国产精品69毛片高清亚洲| 国产老妇另类xxxxx| 日本道免费精品一区二区三区| 97久久超碰国产精品电影| av一区二区三区黑人| 日韩成人午夜精品| 国产乱妇无码大片在线观看| 成人黄色软件下载| 日本韩国欧美在线| 国产三级精品视频| 1024精品合集|