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

相关文章
相关标签/搜索