hibernate的主鍵生成器:
generator元素:表示了乙個主鍵生成器,它用來為持久化類例項生成唯一的標識 。
1.1 程式設計師自己控制:assigned
1.2 資料庫控制:(mysql) identity(標識列/自動增長)( oracle) sequence
1.3 hibernate控制:increment uuid/uuid.hex
1.4 其它:native
在公司裡,有些客戶需求是: 公司名_模組名_時間戳(最後)
student id int
worker id varchar
2. 主鍵生成器要求
2.1 assigned
資料型別不限、儲存前必須賦值
2.2 identity(重點掌握)
數字,無需賦值
2.3 sequence(重點掌握)
數字,無需賦值, 預設使hibernate_sequence這個序列,
也可以通過sequence/sequence_name引數賦值
2.4 increment
數字,無需賦值
2.5 uuid/uuid.hex (是由容器自動生成的乙個32位的字串,.hex代表的是十六進製制)
32位的字串,無需賦值,
2.6 native(重點掌握)
等於identity+sequence
自定義主鍵生成器
3.1 *.hbm.xml指定主鍵生成器類
3.2 建立主鍵生成器類
實現org.hibernate.id.identifiergenerator介面即可,並還可以實現org.hibernate.id.configurable介面來讀取一些配置資訊
persistentidentifiergenerator.table
persistentidentifiergenerator.pk
<?xml version="1.0" encoding="utf-8"?>
root
123jdbc:mysql://localhost:3306/bookshop?useunicode=true&characterencoding=utf-8
com.mysql.jdbc.driver
org.hibernate.dialect.mysqldialect
thread
true
true
定義2個實體類,乙個是學生類,乙個是worker(注意資料庫和實體類屬性是一致的)
public class student
public void setsid(integer sid)
public string getsname()
public void setsname(string sname)
}
public class worker
public void setwid(string wid)
public string getwname()
public void setwname(string wname)
再定義2個實體類名.hibernate.xml實體類
<?xml version="1.0" encoding="utf-8"?>
<?xml version="1.0" encoding="utf-8"?>
檢驗配置檔案是否正確:
—
/**
* 1、方便獲取session會話,用來運算元據庫
* 2、用來檢驗所有對映的配置檔案配置是否準確
* @author administrator
* */
public class sessionfactoryutil
public static session getsession()
return session;
} public static void closesession()
} //測試配置是否正常
public static void main(string args)
列如:student.cfg.xml的 sname,變為sname就會報錯(建議看本博所寫的hibernate的入門(1))
如果列名不對,則會報錯如圖:
在寫乙個dao方法:
public class identifierdao
public string addworker(worker worker)
}
然後junit 測試一下:
public class identifierdaotest
@test
public void testaddworker()
}
最後:
public class myidcreate implements identifiergenerator
}
注:為什麼要這個介面:ctrl+shift+t,查uuid和assigned即可(原理)
hibernate主鍵生成
hibernate的主鍵生成器 generator元素 表示了乙個主鍵生成器,它用來為持久化類例項生成唯一的標識 1.1 程式設計師自己控制 assigned 1.2 資料庫控制 identity 標識列 自動增長 sequence 1.3 hibernate控制 increment uuid uu...
Hibernate主鍵生成策略
hibernate主鍵生成策略 1 自動增長identity 適用於mysql db2 ms sql server,採用資料庫生成的主鍵,用於為long short int型別生成唯一標識 使用sql server 和 mysql 的自增欄位,這個方法不能放到 oracle 中,oracle 不支援...
Hibernate主鍵生成策略
1 自動增長identity 適用於mysql db2 ms sql server,採用資料庫生成的主鍵,用於為long short int型別生成唯一標識 使用sql server 和 mysql 的自增欄位,這個方法不能放到 oracle 中,oracle 不支援自增字段,要設定sequence...