配置hibernate根據實體類自動建表功能

Hibernate支持自動建表,在開發階段很方便,可以保證hbm與數據庫表結構的自動同步。

如何使用呢?很簡單,只要在hibernate.cfg.xml里加上如下代碼

Xml代碼<property name="hbm2ddl.auto">update</property>

update:表示自動根據model對象來更新表結構,啓動hibernate時會自動檢查數據庫,如果缺少表,則自動建表;如果表裏缺少列,則自動添加列。

還有其他的參數:
create:啓動hibernate時,自動刪除原來的表,新建所有的表,所以每次啓動後的以前數據都會丟失。

create-drop:啓動hibernate時,自動創建表,程序關閉時,自動把相應的表都刪除。所以程序結束時,表和數據也不會再存在。

PS:數據庫要預先建立好,因爲hibernate只會建表,不會建庫

==========================================


表結構和數據總是在程序執行的時候無端的修改,折騰了好長時間,查了很長時間hibernate的數據庫映射文件和接口程序,始終沒有發現有什麼錯誤,到最後才發現了它!
<property name="hibernate.hbm2ddl.auto" value="update" />
解釋如下:

hibernate.hbm2ddl.auto Automatically validate or export schema DDL to the database when the SessionFactory is created. With create-drop, the database schema will be dropped when the SessionFactory is closed explicitly. eg. validate | update | create | create-drop

其實這個參數的作用主要用於:自動創建|更新|驗證數據庫表結構。
如果沒有此方面的需求建議set value="none".

其它幾個參數的意思:

validate 加載hibernate時,驗證創建數據庫表結構
create 每次加載hibernate,重新創建數據庫表結構
create-drop 加載hibernate時創建,退出是刪除表結構
update 加載hibernate自動更新數據庫結構

如果發現數據庫表丟失或新增,請檢查hibernate.hbm2ddl.auto的配置 可設置 <property name="hibernate.hbm2ddl.auto" value="none" />

建議在開發環境下使用,在生產環境下去掉。

優點:

1、自動創建新表

2、自動創建新字段

3、自動修改字段類型

缺點:

1、不會自動刪除表

2、不會自動刪除字段

3、自動創建的新字段只能是在最後。

針對缺點的建議:定期把數據庫清空(刪除所有表),然後啓動項目,讓hibernate自動創建表結構和索引,當然一些初始化數據需要手工導入。

發佈了14 篇原創文章 · 獲贊 6 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章