?? personoperate.java
字號:
package org.lxh.hibernate.demo01;
import java.util.Iterator;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
/*
* 具體操作Hibernate的類:
* 增加、刪除、修改、按ID查詢、模糊查詢、查詢全部操作
* */
public class PersonOperate {
// 在Hibernate中,所有的操作都是通過Session完成
// 此Session不同于JSP的Session
private Session session = null ;
// 在構造方法之中實例化session對象
public PersonOperate()
{
// 找到Hibernate配置
Configuration config = new Configuration().configure() ;
// 從配置中取出SessionFactory
SessionFactory factory = config.buildSessionFactory() ;
// 從SessionFactory中取出一個Session
this.session = factory.openSession() ;
}
// 所有的操作都是通過session進行的
// 向數據庫中增加數據
public void insert(Person p)
{
// 開始事務
Transaction tran = this.session.beginTransaction() ;
// 執行語句
this.session.save(p) ;
// 提交事務
tran.commit() ;
// 關閉Session
this.session.close() ;
}
// 修改
public void update(Person p)
{
// 開始事務
Transaction tran = this.session.beginTransaction() ;
// 執行語句
this.session.update(p) ;
// 提交事務
tran.commit() ;
}
// 按ID查詢:推薦使用HQL —— 是Hibernate官方推薦的查詢語言
public Person queryById(String id)
{
Person p = null ;
// 使用Hibernate查詢語言
String hql = "FROM Person as p WHERE p.id=?" ;
// 通過Query接口查詢
Query q = this.session.createQuery(hql) ;
q.setString(0,id) ;
List l = q.list() ;
Iterator iter = l.iterator() ;
if(iter.hasNext())
{
p = (Person)iter.next() ;
}
return p ;
}
// 刪除數據
// Hibernate2、Hibernate 3通用的刪除
// 使用此方法刪除數據之前,必須先查找到數據對象,性能呢?
public void delete(Person p)
{
Transaction tran = this.session.beginTransaction() ;
// 執行語句
this.session.delete(p) ;
// 提交事務
tran.commit() ;
}
// 在Hibernate 3之中根據HQL中的語句進行了修改,增加了刪除指令
public void delete(String id)
{
String hql = "DELETE Person WHERE id=?" ;
Query q = this.session.createQuery(hql) ;
// 把參數設置
q.setString(0,id) ;
// 執行更新語句
q.executeUpdate() ;
// 進行事務處理
this.session.beginTransaction().commit() ;
}
// 查詢全部數據,寫HQL
public List queryAll()
{
List l = null ;
String hql = "FROM Person as p" ;
Query q = this.session.createQuery(hql) ;
l = q.list() ;
return l ;
}
// 模糊查詢
public List queryByLike(String cond)
{
List l = null ;
String hql = "FROM Person as p WHERE p.name like ?" ;
Query q = this.session.createQuery(hql) ;
q.setString(0,"%"+cond+"%") ;
l = q.list() ;
return l ;
}
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -