無論是測試,還是增加數據,或是查詢數據,都需要用到sessionFactory產生的session.本著『不寫重復代碼的原則』,我們新建db.MysqlJavaee來供其它類調用。
# db.MysqlJavaee
```
package db;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.service.ServiceRegistryBuilder;
/**
* Mysql類型的Javaee數據庫
* @author panjie
*
*/
public class MysqlJavaee {
static private SessionFactory sessionFactory;
static public Session getCurrentSession() {
// 每個數據庫只需要一個sessionFactory,在這里進行單一實例處理。
if (null == sessionFactory) {
// 實例化并加載數據庫配置文件
Configuration configuration = new Configuration().configure();
// 構造服務注冊對象
ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().
applySettings(configuration.getProperties()).
buildServiceRegistry();
// 創建會話工廠(session factory))
sessionFactory = configuration
.buildSessionFactory(serviceRegistry);
}
// 創建會話(這里的session也是會話的意思,我們以前接觸的http中的session,處理的是用戶與服務器的對話)
return sessionFactory.getCurrentSession();
}
}
```
# 測試
```
package teacher;
import java.util.List;
import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test;
import db.MysqlJavaee;
import entity.Teacher;
public class IndexTest {
@Test
public void getLists() {
// 創建會話(這里的session也是會話的意思,我們以前接觸的http中的session,處理的是用戶與服務器的對話)
Session session = MysqlJavaee.getCurrentSession();
// 開啟事務(使用緩沖池進行數據庫的連接)
Transaction transaction = session.beginTransaction();
// 在這里,必須使用try catch finally語句。來確定會話正常關閉.
// 否則,當操作數據庫產生錯誤時,你可能需要重啟mysql服務
try {
// 新插入兩條記錄
Teacher teacher1 = new Teacher();
teacher1.setName("zhangsan");
Teacher teacher2 = new Teacher();
teacher2.setName("lisi");
session.save(teacher1);
session.save(teacher2);
// 查詢Teacher表,注意:是Teacher ,而不是 teacher
Query query = session.createQuery("from Teacher");
// 預查詢,只有在事務提交時,才進行查詢操作
List<Teacher> teachers = query.list();
for (Teacher teacher : teachers) {
System.out.println(teacher.toString());
}
// 提交事務
transaction.commit();
// 捕獲異常
} catch (HibernateException e) {
throw e;
} finally {
// 如果session處于開啟狀態,則關閉session
if (session.isOpen()) {
// 關閉會話
session.close();
}
}
}
}
```
# TIPS
重構代碼,在運行一些測試語句時,即使我們在hibernate.cfg.xml中,將hbm2ddl.auto配置為create,也不會像以前一樣,每次運行一次程序都會清空一次數據表。這是由于,我們對SessionFactory進行了單例處理。所以單例,是指,不管我們訪問多少次,我們得到的都是同一樣的一個實例。
此時,如果我們想更改表結構,一是可以用以前的方法,每次運行都創建一個新的SessionFactory。二是可以重新啟動Tomcat。Tomcat的停止時,將釋放SessionFactory。再重啟的時候,又會創建一個新的SessionFactory,在創建這個新的SessionFacotry時,則會重新創建新的數據表了。
# 作業
還等什么,快試試吧。
1. 多次運行getLists,看是否每次運行都會增加2條新的記錄。
2. 停止tomcat后,再運行getLists,看是否數據表又回到了初始兩條記錄的狀態.
3. 對代碼更改后,eclipse進行了代碼了重新編譯。
- README
- 第一章:準備
- 第二章:Hello World!
- 第一節:查看工程文件
- 第二節:JDK、JRE與環境變量
- 第三節:index.jsp
- 第三章:Hello Struts
- 第一節:Web.xml
- 第二節:單入口
- 第三節:Hello Struts
- 第四節:觸發C層
- 第四章:建立數據表
- 第一節:建立實體類
- 第二節:測試一
- 第三節:測試二
- 第四節:引入Hibernate
- 第五節:配置Hibernate
- 第六節:建立連接
- 第七節:實體類映射數據表
- 第八節:完善數據表
- 第五章:教師管理
- 第一節:增加數據--add
- 第二節:增加數據--save
- 1 獲取傳入數據數據
- 2 數據寫入測試
- 3 對接C層
- 第三節:數據列表
- 1 獲取數據
- 2 重構代碼
- 3 C層對接--初始化
- 4 C層添加數據
- 5 V層顯示數據
- 6 獲取數據庫中數據
- 7 顯示性別
- 8 分頁
- 9 條件查詢
- 第四節:修改數據
- 1 edit
- 2 update
- 第五節:刪除數據
- 第六節:總結
- 第六章:重構C層
- 第一節:繼承ActionSupport類
- 第二節:數據驗證
- 第七章:前臺分離(前臺)
- 第一節:環境搭建
- 第二節:運行環境
- 第三節:共享開發環境
- 第四節:生產環境
- 第八章:前臺開發(前臺)
- 第一節:本地化
- 第二節:教師列表
- 1 引入M層
- 2 模擬后臺返回數據
- 3 C與M對接
- 4 C與V對接
- 第九章:前后臺對接(前后臺)
- 第一節:后臺輸出json(后臺)
- 第二節:對接前臺(全棧)
- 第二節:對接API(前臺)
- 第二節:跨域請求(后臺)
- 第三節:重構代碼(前臺)
- 第十章:重構后臺M層
- 第一節:數據訪問DAO層
- 第二節:項目整體重構
- 第十一章:用戶登陸(前后臺)
- 第一節:制定規范
- 第二節:定制測試用例
- 第三節:后臺輸入測試代碼(后臺)
- 第四節:postman(后臺)
- 第五節:新建用戶登陸模塊(前臺)
- 第六節:代碼重構(前臺)
- 第十二章:班級管理(前后臺)
- 第一節:班級列表
- 1 原型開發
- 2 制定規范
- 3 后臺對接開發
- 4 前臺對接開發
- 第二節:Add
- 1 原型開發
- 2 制定規范
- 3 后臺對接開發
- 4 前臺對接開發
- 第三節:Save
- 1 制定規范
- 2 后臺對接開發
- 3 前臺對接開發
- 第四節:Edit
- 1 原型開發
- 2 制定規范
- 3 后臺對接開發
- 4 前臺對接開發
- 第五節:Update
- 1 制定規范
- 2 后臺對接開發
- 3 前臺對接開發
- 第六節:Delete
- 1 制定規范
- 2 后臺對接開發
- 3 前臺對接開發
- 第七節:小結
- 第十三章:班級管理(API)
- 第一節:ER圖
- 第二節:create
- 1 實體層
- 2 dao層
- 3 service(server)層
- 4 action層
- 第三節:ManyToOne
- 第四節:Read
- 1 service(server)層
- 2 action層
- 第五節:update
- 1 service(server)層
- 2 action層
- 第六節:update
- 第十四章:重構服務層