Hibernate中主键生成策略
主鍵生成策略
increment
identity
sequence
native
uuid
assigned
1) increment
由hibernate完成 主鍵遞增,
原理:select max(id) , insert時max(id)+1 ,完成主鍵遞增
優點:跨數據庫
缺點:多線程并發訪問問題(第一個線程執行成功,第二個線程報錯)
2) identity
由底層數據庫來完成自增 ,要求數據庫必須支持自增主鍵? mysql支持 ,oracle不支持
3) sequence
編號列生成由底層數據庫提供序列,來完成主鍵自增,要求數據庫必須支持序列 mysql不支持,oracle支持
create sequence myseq; 創建序列
insert into customer values (myseq.nextval); 插入數據時調用序列,序列+1
4) native
采用數據庫支持自增策略, mysql就用identity 、oracle就用sequence
策略1) ---> 策略4) 要求數據庫主鍵必須為數字 ,因為只有數字才能自增
5) uuid
32位 唯一字符串, 主鍵使用varchar 類型
真實開發中,用程序提供uuid值
6) assigned
手動指定主鍵的值,該主鍵一般有實際意義,例如訂單單號(20160114-A002)20160114-B001? 20160114-C002。
復合主鍵,是一種特殊 assigned類型 自然主鍵 (通常需要手動指定),PO類必須實現Serializable接口
??? <class name="cn.happy.entity.Person" table="person">
??? ??? <composite-id>
??? ??? ??? <key-property name="firstname"></key-property>
??? ??? ??? <key-property name="secondname"></key-property>
??? ??? </composite-id>
??? </class>
7)foreign
使用另外一個相關聯的對象的標識符。它通常和?<one-to-one>?聯合起來使用。
8)hilo
使用一個高/低位算法高效的生成?long,short?或者?int?類型的標識符。給定一個表和字段(默認分別是hibernate_unique_key?和?next_hi)作為高位值的來源。高/低位算法生成的標識符只在一個特定的數據庫中是唯一的。
9)select
通過數據庫觸發器選擇一些唯一主鍵的行并返回主鍵值來分配一個主鍵。
java對象的三種狀態
?持久態:
??? Student stu=new Student()
? ? Session.save(stu);
Session以及數據庫都有
?游離態:
???? stu.setId(1);
???? Session.close();
Session沒有 數據庫中有
? 瞬時態:
? Student stu=new Student()
體現:在Session中以及DB都沒有
三種狀態之間的轉換:
?
該圖從類型上劃分為“活動圖”
使用new關鍵字構建對象,該對象的狀態是瞬時狀態。
1 瞬時狀態轉為持久狀態
使用Session對象的save()或saveOrUpdate()方法保存對象后,該對象的狀態由瞬時狀態轉換為持久狀態。
使用Session對象的get()或load()方法獲取對象,該對象的狀態是持久狀態。
2 持久狀態轉為瞬時狀態
執行Session對象的delete()方法后,對象由原來的持久狀態變為瞬時狀態,因為此時該對象沒有與任何的數據庫數據關聯。
3 持久狀態轉為游離狀態
吃行了Session對象的evict()、clear()或close()方法,對象由原來的持久狀態轉為游離狀態。
4 游離狀態轉為持久狀態
重新獲取Session對象,執行Session對象的update()或saveOrUpdate()方法,對象由游離狀態轉為持久狀態,該對象再次與Session對象相關聯。
5 游離狀態轉為瞬時狀態
執行Session對象的delete()方法,對象由游離狀態轉為瞬時狀態。
處于瞬時狀態或游離狀態的對象不再被其他對象引用時,會被Java虛擬機按照垃圾回收機制處理。
?
轉載于:https://www.cnblogs.com/hq-123/p/5818513.html
總結
以上是生活随笔為你收集整理的Hibernate中主键生成策略的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 耳机煲机软件测试自学,乐味煲耳机软件教程
- 下一篇: modbus rtu功能码理解