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