Hibernate入門(IDEA下自動生成映射文件及實體類)

1.Hibernate開發步驟

1.創建Hibernate配置文件
2.創建持久化類
3.創建對象-關係映射文件
4.通過Hibernate API編寫訪問數據庫的代碼

2.創建一個hibernate項目(IntelliJ IDEA下演示)

後續需要連接數據庫,手動導入這兩個包

3.配置文件

修改hibernate.cfg.xml

<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
​
        <!-- 配置連接數據庫的基本信息 -->
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
        <!--數據庫用戶名配置-->
        <property name="connection.username">root</property>
        <!--數據庫密碼配置-->
        <property name="connection.password">root</property>
​
        <!-- 配置 hibernate 的基本信息 -->
        <!-- hibernate 所使用的數據庫方言 -->
        <property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>
        <!--56-->
        <!-- 執行操作時是否在控制檯打印 SQL -->
        <property name="show_sql">true</property>
​
        <!-- 是否對 SQL 進行格式化 -->
        <property name="format_sql">true</property>
​
        <!-- 指定自動生成數據表的策略 -->
        <property name="hbm2ddl.auto">update</property>
        <!-- 後面的這兩行爲後續自動生成實體類及配置文件時自動生成的-->
        <mapping class="com.yfy.hibernate.entity.NewsEntity"/>
        <mapping resource="com/yfy/hibernate/entity/NewsEntity.hbm.xml"/>
​
    </session-factory>
</hibernate-configuration>

生成表的策略:

  • create:會根據*.hbm.xml文件來生成數據表,但是每次運行都會刪除上一次的表,重新生成表

  • create-drop:會根據*.hbm.xml文件來生成數據表,但是SessionFactory一關閉,表就自動刪除

  • update:最常用的屬性,會根據*.hbm.xml文件生成表,但若.hbm.xml文件和數據庫中對應的數據表的結構不同,Hibernate將更新數據表結構

  • validate:會和數據庫中的表進行比較,若*.hbm.xml文件中的列在數據表中不存在,則拋出異常

4.配置數據庫

(1)點擊Database

(2)選擇數據庫

 

(3)配置數據庫後測試連接是否成功

 

(4)表結構如下

(5)自動生成hibernate實體類和映射文件

 

(5)生成的實體類和配置文件如下

創建持久化java類

1.提供一個無參構造器
2.提供一個標識屬性
3.爲類的持久化類字段聲明訪問方法(get/set)
4.使用非final類(在運行時生成代理 cglib)
5.重寫equals和hashCode方法

NewsEntity.java

@Entity
@Table(name = "news", schema = "hibernate")
public class NewsEntity {
​
    private int id;
    private String title;
    private String author;
    private Date data;
​
    @Id
    @Column(name = "id")
    public int getId() {
        return id;
    }
​
    public void setId(int id) {
        this.id = id;
    }
​
    @Basic
    @Column(name = "title")
    public String getTitle() {
        return title;
    }
​
    public void setTitle(String title) {
        this.title = title;
    }
​
    @Basic
    @Column(name = "author")
    public String getAuthor() {
        return author;
    }
​
    public void setAuthor(String author) {
        this.author = author;
    }
​
    @Basic
    @Column(name = "data")
    public Date getData() {
        return data;
    }
​
    public void setData(Date data) {
        this.data = data;
    }
​
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        NewsEntity that = (NewsEntity) o;
        return id == that.id &&
                Objects.equals(title, that.title) &&
                Objects.equals(author, that.author) &&
                Objects.equals(data, that.data);
    }
​
    @Override
    public int hashCode() {
​
        return Objects.hash(id, title, author, data);
    }
​
    @Override
    public String toString() {
        return "NewsEntity{" +
                "id=" + id +
                ", title='" + title + '\'' +
                ", author='" + author + '\'' +
                ", data=" + data +
                '}';
    }
}

NewsEntity.hbm.xml

<?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">
<hibernate-mapping>
​
    <class name="com.yfy.hibernate.entity.NewsEntity" table="news" schema="hibernate">
        <id name="id" column="id"/>
        <property name="title" column="title"/>
        <property name="author" column="author"/>
        <property name="data" column="data"/>
    </class>
</hibernate-mapping>

(6)編寫測試類

HibernateTest.java

public class HibernateTest {
​
    private Session getSession() {
​
        //1. 創建一個 SessionFactory 對象
        SessionFactory sessionFactory = null;
​
        //1). 創建 Configuration 對象: 對應 hibernate 的基本配置信息和 對象關係映射信息
        Configuration configuration = new Configuration().configure();
​
        //4.0 之前這樣創建
//      sessionFactory = configuration.buildSessionFactory();
​
        //2). 創建一個 ServiceRegistry 對象: hibernate 4.x 新添加的對象
        //hibernate 的任何配置和服務都需要在該對象中註冊後纔能有效.
        ServiceRegistry serviceRegistry =
                new ServiceRegistryBuilder().applySettings(configuration.getProperties())
                        .buildServiceRegistry();
​
        //3).
        sessionFactory = configuration.buildSessionFactory(serviceRegistry);
​
        //2. 創建一個 Session 對象
        return sessionFactory.openSession();
    }
​
    @Test
    public void testGet() {
​
        Session session = getSession();
        NewsEntity newsEntity = (NewsEntity) session.get(NewsEntity.class, 2);
        System.out.println(newsEntity);
        session.close();
    }
​
    @Test
    public void testAdd() {
​
        Session session = getSession();
        //3. 開啓事務
        Transaction transaction = session.beginTransaction();
​
        //4. 執行保存操作
        NewsEntity newsEntity = new NewsEntity();
//        newsEntity.setId(2);
        newsEntity.setTitle("java語句很強嗎");
        newsEntity.setAuthor("hello123");
        newsEntity.setData(new Date());
        session.save(newsEntity);
​
        //5. 提交事務
        transaction.commit();
​
        //6. 關閉 Session
        session.close();
    }
}

5.具體類介紹

Configuration類

負責管理Hibernate的配置信息、包括如下內容:

  • Hibernate運行的底層信息:數據庫的URL、用戶名、密碼、JDBC驅動類,數據庫Dialect,數據庫連接池等(hibernate.cfg.xml)

  • 持久化類與數據庫的映射關係(*.hbm.xml)

創建Configuration的兩種方式

//屬性文件(hibernate.properties)
Configuration cfg=new Configuration();
​
//xml文件(hibernate.cfg.xml)
Configuration cfg=new Configuration().configure()'
  
//還支持帶參數的訪問
File file=new File("hibernate.xml");
Configuration cfg=new Configuration().configure(file);

SessionFactory接口

  • 針對單個數據庫映射關係經過編譯後的內存鏡像,是線程安全的

  • SessionFactory對象一旦構造完畢,即被賦予特定的配置信息

  • SessionFactory是生成Session的工廠

  • Hibernate4新增了一個ServiceRegistry接口,所有基於Hibernate的配置或者服務都必須統一向這個ServiceRegisty註冊後才能生效

Session接口

Session是應用程序與數據庫之間交互操作的一個單線程對象,是Hibernate運作的中心,所有持久化對象都必須在session的管理下纔可以進行持久化操作。

Session對象有一個一級緩存,顯式執行flush之前,所有的持久層操作的數據都緩存在session對象中。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章