日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

hibernate里的generator中class =value介绍

發(fā)布時(shí)間:2025/7/14 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hibernate里的generator中class =value介绍 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

在*.hbm.xml必須聲明的<generator>子元素是一個(gè)Java類的名字,用來(lái)為該持久化類的實(shí)例生成唯一的標(biāo)識(shí)。
<generator class="sequence"/>
這是一個(gè)非常簡(jiǎn)單的接口;某些應(yīng)用程序可以選擇提供他們自己特定的實(shí)現(xiàn)。當(dāng)然,Hibernate提供了很多內(nèi)置的實(shí)現(xiàn)。下面是一些內(nèi)置生成器的快捷名字:
increment(遞增)
??? 用于為long, short或者int類型生成唯一標(biāo)識(shí)。只有在沒(méi)有其他進(jìn)程往同一張表中插入數(shù)據(jù)時(shí)才能使用。 在集群下不要使用。(補(bǔ)充:主鍵按數(shù)值順序遞增,此方式的實(shí)現(xiàn)機(jī)制為在當(dāng)前實(shí)例中維持一個(gè)變量,以保存著當(dāng)前的最大值,之后每次需要生成主鍵的時(shí)候在此值上加1作為主鍵,可能產(chǎn)生的問(wèn)題:如果當(dāng)前有多個(gè)實(shí)例訪問(wèn)同一個(gè)數(shù)據(jù)庫(kù),那么由于各個(gè)實(shí)例都維持主鍵狀態(tài),不同實(shí)例可呢生成同樣 主鍵,從而造成主鍵重復(fù)異常,因此,如果同一個(gè)數(shù)據(jù)庫(kù)有多個(gè)實(shí)例訪問(wèn),此方式必須避免使用。)
identity
??? 對(duì)DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的內(nèi)置標(biāo)識(shí)字段提供支持。返回的標(biāo)識(shí)符是long, short 或者int類型的。(補(bǔ)充:采用數(shù)據(jù)庫(kù)提供的主鍵生成機(jī)制,如sqlserver mysql中的自增主鍵生成機(jī)制)
sequence (序列)
??? 在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的標(biāo)識(shí)符是long, short或者 int類型的。
hilo (高低位)
??? 使用一個(gè)高/低位算法來(lái)高效的生成long, short或者 int類型的標(biāo)識(shí)符。給定一個(gè)表和字段(默認(rèn)分別是是hibernate_unique_key 和next_hi)作為高位值得來(lái)源。高/低位算法生成的標(biāo)識(shí)符只在一個(gè)特定的數(shù)據(jù)庫(kù)中是唯一的。在使用JTA獲得的連接或者用戶自行提供的連接中,不要使用這種生成器。(補(bǔ)充:需要一個(gè)額外的數(shù)據(jù)庫(kù)表保存主鍵生成歷史狀態(tài))
seqhilo(使用序列的高低位)
??? 使用一個(gè)高/低位算法來(lái)高效的生成long, short或者 int類型的標(biāo)識(shí)符,給定一個(gè)數(shù)據(jù)庫(kù)序列(sequence)的名字。(補(bǔ)充:類似hilo算法實(shí)現(xiàn)主鍵生成機(jī)制,只是主鍵歷史狀態(tài)保存在sequence中,適用于支持sequence的數(shù)據(jù)庫(kù),如Oracle)
uuid.hex
??? 用一個(gè)128-bit的UUID算法生成字符串類型的標(biāo)識(shí)符。在一個(gè)網(wǎng)絡(luò)中唯一(使用了IP地址)。UUID被編碼為一個(gè)32位16進(jìn)制數(shù)字的字符串。
uuid.string
??? 使用同樣的UUID算法。UUID被編碼為一個(gè)16個(gè)字符長(zhǎng)的任意ASCII字符組成的字符串。不能使用在PostgreSQL數(shù)據(jù)庫(kù)中
native(本地)
??? 根據(jù)底層數(shù)據(jù)庫(kù)的能力選擇identity, sequence 或者h(yuǎn)ilo中的一個(gè)。(詳解:由hibernate根據(jù)數(shù)據(jù)庫(kù)適配器中的定義,自動(dòng)采用identify、hilo、sequence的其中一種作為主鍵生成方式)
assigned(程序設(shè)置)
??? 讓應(yīng)用程序在save()之前為對(duì)象分配一個(gè)標(biāo)示符。(補(bǔ)充:主鍵由運(yùn)用邏輯產(chǎn)生,數(shù)據(jù)交由hibernate保存時(shí),主鍵值已經(jīng)設(shè)置完畢,無(wú)需hibernate干預(yù))
foreign(外部引用)
??? 使用另外一個(gè)相關(guān)聯(lián)的對(duì)象的標(biāo)識(shí)符。和<one-to-one>聯(lián)合一起使用!

轉(zhuǎn)載于:https://www.cnblogs.com/henuyuxiang/p/3921646.html

總結(jié)

以上是生活随笔為你收集整理的hibernate里的generator中class =value介绍的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。