Hibernate 根據實體名稱獲得DB表名以及表對應的Sequence name

DB: oracle 10g;session

entityName:com.signaldemand.flank.hibernate.model.實體名oracle

1. 根據實體名獲取DB表相對應的表名hibernate

Class<?> clazz = CrudServiceHelper.getClassForName(entityName);
AbstractEntityPersister classMetadata = (AbstractEntityPersister)_sessionFactory.getClassMetadata(clazz);
String tableName = classMetadata.getTableName();get

 2.獲取DB中全部的表sequence name it

SessionFactory sf = HibernateUtil.getInstance().getSf();
Map mds = sf.getAllClassMetadata();
for (Object entry : mds.entrySet()) {
Entry en = (Entry) entry;
EntityPersister ep = (EntityPersister) en.getValue();
IdentifierGenerator idGen = ep.getIdentifierGenerator();
if (idGen instanceof SequenceGenerator) {
SequenceGenerator seqGen=(SequenceGenerator)idGen;
seqGen.getSequenceName();//這裏就獲得sequenceName了。
}
} io

3. 一次性取出多個序列值(一般用在導入數據時,表若是有多條記錄,先查詢所要的sequence再進行設置id)table

select sequenceName.nextval from (select 1 from all_objects where rownum <= 100)class

標註:一個足夠大的表,確保知足想獲取的序列數量(表的數據量至少要有你想要的序列數量那麼多)object

all_objects 爲系統表select

相關文章
相關標籤/搜索