一、設置映射配置文件
<1> 導入約束:
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<2>配置字段
<hibernate-mapping>
/*
* 1.name屬性: 實體類的路徑
* 2.table屬性: 即將創建數據表的名稱
*/
<class name="com.company.User" table="user">
//配置實體類中定義的屬性
/*
* 1.name屬性: 實體類中聲明的屬性
* 2.column屬性: 數據表中字段(可以不寫.默認與name的值相同)
*/
<id name="uid" column="uid">
<!--設置數據表id增長策略-->
<generator class="native"></generator>
</id>
<property name="username" column="username"></property>
<property name="password" column="password"></property>
<property name="address" column="address"></property>
</class>
</hibernate-mapping>
二. 配置hibernate核心配置文件
<1>導入約束
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<2>設置配置信息
<hibernate-configuration>
<session-factory>
<!--配置數據庫信息-->
<property name="hibernate.connection.driver_class ">com.mysql.jdbc.Driver</property> // 加載數據庫驅動
<property name="hibernate.connection.url">jdbc:mysql:///hibernateDemo1</property> // 設置數據庫地址
<property name="hibernate.connection.username">root</property> //設置數據庫賬戶
<property name="hibernate.connection.password">root</property> //設置數據庫密碼
<!--配置hibernate信息-->
<!--設置程序執行時在控制臺輸出底層sql語句-->
<property name="hibernate.show_sql">true</property>
<!--設置輸出底層sql語句格式化-->
<property name="hibernate.format_sql">true</property>
<!--設置hibernate自動更新表數據,沒有表就自動創建-->
<property name="hibernate.hbm2ddl.auto">update</property>
<!--配置數據庫方言-->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!--引入映射文件-->
<mapping resource="com/company/User.hbm.xml"></mapping>
</session-factory>
</hibernate-configuration>
三. 創建實體類User
public class User {
private int did;
private String username;
private String password;
private String address;
public int getUid() {
return did;
}
public void setUid(int uid) {
this.uid = did;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
四. 實現代碼
//第一步: 加載hibernate核心文件
Configuration cfg = new Configuration();cfg.configure();
//第二步: 創建SessionFactory對象
/*
* 1.責初始化Hibernate
* 2.數據存儲源的代理,負責創建Session對象
* 3.他是不是輕量級的
* 4.通常而言,每個項目創建一個SessionFactory對象就夠了
*/
SessionFactory sessionFactory = cfg.buildSessionFactory();
//第三步: 使用SessionFactory 創建session對象
Session session = sessionFactory.openSession();
//第四步: 開啟事務
/*
* 1. 事務是訪問并可能更新數據庫中各種數據項的一個程序執行單元
* 2.開啟事務是由session對象調用beginTransaction()方法,返回的是Transaction對象
* 3.事務關閉是由Transaction對象調用commit()方法[關閉]或者rollback()方法[回滾]
*/
Transaction tx = session.beginTransaction();
//第五步: 寫具體邏輯crud操作
//添加數據
User user = new User();
user.setUsername("xiaoHong");
user.setPassword("1314");
user.setAddress("Japan");
session.save(user);
//第六步: 提交事物
tx.commit();
//第七步: 關閉資源
session.close();
sessionFactory.close();
五. 抽取hibernate工具類
//將SeesionFactory的創建放在static代碼塊中,全程只執行一次,提高程序的執行效率
public class HibernateUtils {
private static Configuration cfg = null;
private static SessionFactory sessionFactory = null;
//全程只調用一次,只創建一次SeesionFactory對象
static {
cfg = new Configuration();
cfg.configure();
sessionFactory = cfg.buildSessionFactory();
}
//獲取SessionFactory對象
public static SessionFactory getSessionFactory(){
return sessionFactory;
}
}
六. 實現代碼(使用工具類)
//第一步: 調用HibernateUtils工具類創建Configuration對象和SessionFactory對象
SessionFactory sessionFactory = HibernateUtils.getSessionFactory();
//第二步: 使用SessionFactory 創建session對象
Session session = sessionFactory.openSession();
//第三步: 開啟事務
Transaction tx = session.beginTransaction();
//第四步: 寫具體邏輯crud操作
//添加數據
User user = new User();
user.setUsername("xiaoHong");
user.setPassword("1314");
user.setAddress("Japan");
session.save(user);
//第五步: 提交事物
tx.commit();
//第六步: 關閉資源
session.close();
sessionFactory.close();