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