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