分析Hibernate自增主鍵
Hibernate提供了產生自動增長類型主鍵的多種策略,Hibernate自增主鍵有很多方面,這里以increment為例說明具體用法:
1、在數據庫中建立表,主鍵名稱為ID,類型為varchar2(字符串型)
2、在**.hbm.xml(hibernate映射文件)中配置如下
3、在java文件中對表增加記錄時,只需添加除ID外的其他字段,然后save即可,相關java代碼如下:
- Session s = HibernateUtil.currentSession(); Transaction tx = s.beginTransaction(); Test test = new Test(); String uname = httpServletRequest.getParameter("uname"); test.setUname(uname); //只需對uname進行set,id由hibernate生成 s.save(test); tx.commit();
- 文章出處:http://www.diybl.com/course/3_program/java/javajs/2008619/126630.html
4、使用其它策略的方法基本一致,例如hilo、seqhilo等 Generator 為每個 POJO 的實例提供唯一標識。
一般情況,我們使用“native”。class 表示采用由生成器接口net.sf.hibernate.id.IdentifierGenerator 實現的某個實例,其中包括:
◆“assigned” 主鍵由外部程序負責生成,在 save() 之前指定一個。
◆“hilo” 通過hi/lo 算法實現的主鍵生成機制,需要額外的數據庫表或字段提供高位值來源。
◆“seqhilo” 與hilo 類似,通過hi/lo 算法實現的主鍵生成機制,需要數據庫中的 Sequence,適用于支持 Sequence 的數據庫,如Oracle。
◆“increment” 主鍵按數值順序遞增。此方式的實現機制為在當前應用實例中維持一個變量,以保存著當前的***值,之后每次需要生成主鍵的時候將此值加1作為主鍵。這種方式可能產生的問題是:不能在集群下使用。
◆“identity” 采用數據庫提供的主鍵生成機制。如DB2、SQL Server、MySQL 中的主鍵生成機制。
◆“sequence” 采用數據庫提供的 sequence 機制生成主鍵。如 Oralce 中的Sequence。
◆“native” 由Hibernate自增主鍵根據使用的數據庫自行判斷采用 identity、hilo、sequence 其中一種作為主鍵生成方式。
◆“uuid.hex” 由Hibernate自增主鍵基于128 位 UUID 算法 生成16 進制數值(編碼后以長度32 的字符串表示)作為主鍵。
◆“uuid.string” 與uuid.hex 類似,只是生成的主鍵未進行編碼(長度16),不能應用在 PostgreSQL 數據庫中。
◆“foreign” 使用另外一個相關聯的對象的標識符作為主鍵。
【編輯推薦】
◆