
| 序號 | 技術 | 作用 |
|---|---|---|
| 1 | Struts | 基于mvc模式的應用層框架技術! |
| 2 | Spring | 創建對象、處理對象的依賴關系以及框架整合! |
| 3 | Hibernate | 基于持久層的框架(數據訪問層使用)! |
(1)操作XML數據
(2)使用Jdbc技術
a)原始的jdbc操作, Connection/Statement/ResultSet
b)自定義一個持久層框架, 封裝了dao的通用方法
c)DbUtils組件, 輕量級的dao的組件;
d)Hibernate技術【hibernate最終執行的也是jdbc代碼!】
O, Object 對象
R, Realtion 關系 (關系型數據庫: MySQL, Oracle…)
M,Mapping 映射
ORM, 對象關系映射!
ORM, 解決什么問題?
存儲: 把對象的數據直接保存到數據庫
獲取: 直接從數據庫拿到一個對象
想做到上面2點,必須要有映射!
Hibernate是ORM的實現!
1、源碼,引入jar文件
2、配置(.xml or .properties)
3、API
Hibernate開發步驟
(1)下載源碼
版本:hibernate-distribution-3.6.0.Final,下載地址如下:
https://sourceforge.net/projects/hibernate/files/hibernate3/3.6.0.Final/

選擇141.0MB的文件,它的文件格式是.zip格式的,而下面的文件是.gz格式的。
解壓之后,它的源碼位于hibernate-distribution-3.6.0.Final\project\core\src目錄下
(2)引入jar文件
a)hibernate3.jar (核心文件)
位于hibernate-distribution-3.6.0.Final目錄下

b)required (必須引入的jar,共6個)
位于hibernate-distribution-3.6.0.Final\lib\required目錄下

c)jpa 目錄
位于hibernate-distribution-3.6.0.Final\lib\jpa目錄

d)數據庫驅動包(我用的是mysql的驅動包)

(3)寫對象以及對象的映射
a)Employee.java 對象
import java.util.Date;
public class Employee
{
private int empId;
private String empName;
private Date workDate;
public int getEmpId()
{
return empId;
}
public void setEmpId(int empId)
{
this.empId = empId;
}
public String getEmpName()
{
return empName;
}
public void setEmpName(String empName)
{
this.empName = empName;
}
public Date getWorkDate()
{
return workDate;
}
public void setWorkDate(Date workDate)
{
this.workDate = workDate;
}
}b)Employee.hbm.xml 對象的映射 (映射文件)
(.hbm可能是hibernate mapping的縮寫)
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <!-- This mapping demonstrates content-based discrimination for the table-per-hierarchy mapping strategy, using a formula discriminator. --> <hibernate-mapping package="com.rk.hibernate.a_hello"> <class name="Employee" table="employee"> <!-- 主鍵,映射 --> <id name="empId" column="id"> <generator class="native"/> </id> <!-- 非主鍵,映射 --> <property name="empName" column="empName"></property> <property name="workDate" column="workDate"></property> </class> </hibernate-mapping>
(4)主配置文件 src/hibernate.cfg.xml
a)數據庫連接配置
b)加載所用的映射(*.hbm.xml)
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <!-- 通常,一個session-factory節點代表一個數據庫 --> <session-factory> <!-- 1. 數據庫連接配置 --> <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> <property name="hibernate.connection.url">jdbc:mysql:///test</property> <!-- 等同于jdbc:mysql://localhost:3306/test --> <property name="hibernate.connection.username">root</property> <property name="hibernate.connection.password">root</property> <!-- 數據庫方言配置, hibernate在運行的時候,會根據不同的方言生成符合當前數據庫語法的sql --> <property name="hibernate.dialect">org.hibernate.dialect.MySQL5Dialect</property> <!-- 2. 其他相關配置 --> <!-- 2.1 顯示hibernate在運行時候執行的sql語句 --> <property name="hibernate.show_sql">true</property> <!-- 2.2 格式化sql --> <property name="hibernate.format_sql">true</property> <!-- 2.3 自動建表 --> <property name="hibernate.hbm2ddl.auto">update</property> <!-- 3. 加載所有映射 --> <mapping resource="com/rk/hibernate/a_hello/Employee.hbm.xml"/> </session-factory> </hibernate-configuration>
(5)測試
package com.rk.hibernate.a_hello;
import java.util.Date;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.classic.Session;
public class App
{
public static void main(String[] args)
{
// 對象
Employee emp = new Employee();
emp.setEmpName("張三");
emp.setWorkDate(new Date());
/*
* 主體思路:Configuration-->SessionFactory-->Session
* 細節:Session-->Transaction,必須由session創建transaction,否則無法保存。
*/
// 獲取加載配置文件的管理類對象
Configuration config = new Configuration();
config.configure();
// 創建session的工廠對象
SessionFactory sessionFactory = config.buildSessionFactory();
// 創建session (代表一個會話,與數據庫連接的會話)
Session session = sessionFactory.openSession();
// 開啟事務
Transaction transaction = session.beginTransaction();
//保存數據
session.save(emp);
// 提交事務
transaction.commit();
// 關閉
session.close();
sessionFactory.close();
System.out.println("Over");
}
}免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。