使用Hibernate根據(jù)實(shí)體類自動(dòng)生成表的方法
第一種方法
這種方法需要配置 hibernate.cfg.xml 的屬性 hibernate.hbm2ddl.auto
,該屬性值的具體說明如下:
值 | 說明 |
update | 實(shí)體對(duì)應(yīng)的表如果不存在則會(huì)創(chuàng)建。如果實(shí)體中新增加了字段,會(huì)在相應(yīng)的表中增加一列 |
create | 每次啟動(dòng) Hibernate 都會(huì)創(chuàng)建表。在 Hiberante 啟動(dòng)時(shí),會(huì)先刪除實(shí)體對(duì)應(yīng)的表,然后再創(chuàng)建實(shí)體對(duì)應(yīng)的表 |
create-drop | 每次啟動(dòng) Hibernate 都會(huì)創(chuàng)建表,并執(zhí)行完后刪除表。在 Hibernate 啟動(dòng)時(shí),先刪除實(shí)體對(duì)應(yīng)的表,然后創(chuàng)建實(shí)體對(duì)應(yīng)的數(shù)據(jù)表。SessionFactory執(zhí)行close()時(shí)刪除表。 |
validate | 檢查hbm的文件,如果和數(shù)據(jù)庫的字段不一致會(huì)拋異常 |
create-only | 在Hibernate啟動(dòng)時(shí),對(duì)實(shí)體僅會(huì)執(zhí)行建表語句,即使實(shí)體對(duì)應(yīng)的表已經(jīng)存在了,也會(huì)重復(fù)執(zhí)行建表語句 |
drop | 在Hiberante啟動(dòng)時(shí),對(duì)實(shí)體對(duì)應(yīng)的表執(zhí)行刪除語句,即使實(shí)體不存在對(duì)應(yīng)的表,都會(huì)執(zhí)行表刪除語句 |
none | 在Hiberante啟動(dòng)時(shí),不會(huì)執(zhí)行任何操作 |
第一步:先寫好實(shí)體類 Ticket
package priv.lwx.hibernate.basic.entity; import java.io.ByteArrayInputStream; /** * description * * @author liaowenxiong * @date 2022/11/26 19:31 */ public class Ticket { private Integer id; private Integer number; private Byte version; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public Integer getNumber() { return number; } public void setNumber(Integer number) { this.number = number; } public Byte getVersion() { return version; } public void setVersion(Byte version) { this.version = version; } }
第二步:寫好映射配置文件 Ticket.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 package="priv.lwx.hibernate.basic.entity"> <class name="Ticket" table="ticket" schema="test"> <id name="id" type="integer"> <column name="id" unique="true"/> <!--主鍵值的生成方式--> <generator class="native"/> </id> <property name="number" type="integer"> <column name="number" not-null="true"/> </property> <property name="version" type="byte"> <column name="version" not-null="true"/> </property> </class> </hibernate-mapping>
第三步:配置 hibernate.cfg.xml
配置屬性 hibernate.hbm2ddl.auto
:
<property name="hibernate.hbm2ddl.auto">update</property>
引入映射配置文件:
<mapping resource="priv/lwx/hibernate/basic/entity/Ticket.hbm.xml"/>
第四步:執(zhí)行Hibernate的查詢代碼
public class TicketTest { @Test public void testSaveTicket() { Session session = HibernateUtils.getSession(); Transaction tx = session.beginTransaction(); Ticket ticket = new Ticket(); ticket.setNumber(100); ticket.setVersion((byte) 1); session.save(ticket); HibernateUtils.closeSession(); } }
執(zhí)行上述的 session.save(ticket);
,會(huì)去解析 hibernate.cfg.xml 和 Ticket.hbm.xml,解析到屬性 hibernate.hbm2ddl.auto 的值為 update
,就會(huì)去獲取數(shù)據(jù)表的結(jié)構(gòu),如果獲取不到則會(huì)生成建表語句,如果獲取到了,則會(huì)逐個(gè)字段與映射文件進(jìn)行比對(duì),如果發(fā)現(xiàn)數(shù)據(jù)表字段缺少、字段名不同、數(shù)據(jù)類型不同等情況,則會(huì)生成相應(yīng)的DDL語句對(duì)數(shù)據(jù)表的結(jié)構(gòu)進(jìn)行更新。如果數(shù)據(jù)表的字段比映射文件中的字段多,并不會(huì)把數(shù)據(jù)表中多出的字段刪除掉。DDL語句生成好之后,save() 方法會(huì)根據(jù)傳入的實(shí)體對(duì)象的屬性、hbm 文件生成 DML 語句,再結(jié)合JDBC的API訪問數(shù)據(jù)庫,完成數(shù)據(jù)表結(jié)構(gòu)的更新以及數(shù)據(jù)的存儲(chǔ)。
第二種方法
public void testAutoCreateTable() { ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().configure().build(); Metadata metadata = new MetadataSources(serviceRegistry).buildMetadata(); //工具類 SchemaExport export = new SchemaExport(); // 會(huì)根據(jù)hbm文件將實(shí)體類對(duì)應(yīng)的數(shù)據(jù)表全部刪除再創(chuàng)建表 export.create(EnumSet.of(TargetType.STDOUT), metadata); } }
到此這篇關(guān)于使用Hibernate根據(jù)實(shí)體類自動(dòng)生成表的方法的文章就介紹到這了,更多相關(guān)Hibernate根據(jù)實(shí)體類自動(dòng)生成表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java之SpringBoot實(shí)現(xiàn)基本增刪改查(前后端分離版)
這篇文章主要介紹了Java中SpringBoot如何實(shí)現(xiàn)基本的增刪改查,前后端分離版,沒有和前端進(jìn)行聯(lián)系,感興趣的小伙伴可以借鑒閱讀本文2023-03-03解決IDEA中 Ctrl+ALT+V這個(gè)快捷鍵無法使用的情況
這篇文章主要介紹了解決IDEA中 Ctrl+ALT+V這個(gè)快捷鍵無法使用的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02Java多線程基礎(chǔ) 線程的等待與喚醒(wait、notify、notifyAll)
這篇文章主要介紹了Java多線程基礎(chǔ) 線程的等待與喚醒,需要的朋友可以參考下2017-05-05Java BufferedWriter BufferedReader 源碼分析
本文是關(guān)于Java BufferedWriter ,BufferedReader 簡(jiǎn)介、分析源碼 對(duì)Java IO 流深入了解,希望看到的同學(xué)對(duì)你有所幫助2016-07-07springboot整合minio實(shí)現(xiàn)文件存儲(chǔ)功能
MinIO?是一個(gè)基于Apache?License?v2.0開源協(xié)議的對(duì)象存儲(chǔ)服務(wù),它兼容亞馬遜S3云存儲(chǔ)服務(wù)接口,非常適合于存儲(chǔ)大容量非結(jié)構(gòu)化的數(shù)據(jù),本文給大家介紹了springboot整合minio實(shí)現(xiàn)文件存儲(chǔ)功能,文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12SPRING BOOT啟動(dòng)命令參數(shù)及源碼詳析
這篇文章主要給大家介紹了關(guān)于SPRING BOOT啟動(dòng)命令參數(shù)及源碼分析的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用SPRING BOOT具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12Java對(duì)象轉(zhuǎn)json JsonFormat注解
這篇文章主要介紹了Java對(duì)象轉(zhuǎn)json JsonFormat注解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05