hibernate 获取实体的表名、主键名、列名(转载+修改)
package com.escs.utils;
import java.util.Iterator;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.cfg.Configuration;
import org.hibernate.mapping.Column;
import org.hibernate.mapping.PersistentClass;
import org.hibernate.mapping.PrimaryKey;
import org.hibernate.mapping.Property;
/**
* 功能描述:根据实体类得到对应的表名、主键名、字段名工具类
* </p>
* 注:po类名须与对应映射文件名一致,即Student.java与Student.hbm.xml<br>
* //修改为主注解方式,此hbm文件已经不需要
*
*
* @Date:Nov 10, 2008
* @Time:3:13:07 PM
*
*/
public class EntityUtil {
private static Configuration hibernateConf;
private static Configuration getHibernateConf() {
if (hibernateConf == null) {
hibernateConf=new Configuration();//*.hbm.xml方式
// hibernateConf=new AnnotationConfiguration().configure();//注解方式
// hibernateConf.buildSessionFactory();//注解方式必须的
}
return hibernateConf;
}
private static PersistentClass getPersistentClass(Class<?> clazz) {
synchronized (EntityUtil.class) {
PersistentClass pc = getHibernateConf().getClassMapping(
clazz.getName());
if (pc == null) {
hibernateConf = getHibernateConf().addClass(clazz);//*.hbm.xml方式 注解方式去掉这个
pc = getHibernateConf().getClassMapping(clazz.getName());
}
return pc;
}
}
/**
* 功能描述:获取实体对应的表名
*
* @param clazz
* 实体类
* @return 表名
*/
public static String getTableName(Class<?> clazz) {
return getPersistentClass(clazz).getTable().getName();
}
/**
* 获取指定列的列名
* @param clazz
* @param num
* @return
*/
public static String getColumnName(Class<?> clazz,int num) {
return getPersistentClass(clazz).getTable().getColumn(num).getName();
}
/**
* 功能描述:获取实体对应表的主键字段名称,只适用于唯一主键的情况
*
* @param clazz
* 实体类
* @return 主键字段名称
*/
public static String getPrimaryKey(Class<?> clazz) {
return getPrimaryKeys(clazz).getColumn(0).getName();
}
/**
* 功能描述:获取实体对应表的主键字段名称
*
* @param clazz
* 实体类
* @return 主键对象primaryKey ,可用primaryKey.getColumn(i).getName()
*/
public static PrimaryKey getPrimaryKeys(Class<?> clazz) {
return getPersistentClass(clazz).getTable().getPrimaryKey();
}
/**
* 功能描述:通过实体类和属性,获取实体类属性对应的表字段名称
*
* @param clazz
* 实体类
* @param propertyName
* 属性名称
* @return 字段名称
*/
public static String getColumnName(Class<?> clazz, String propertyName) {
PersistentClass persistentClass = getPersistentClass(clazz);
Property property = persistentClass.getProperty(propertyName);
Iterator<?> it = property.getColumnIterator();
if (it.hasNext()) {
Column column = (Column) it.next();
return column.getName();
}
return null;
}
}
上述方法可以用个扫描注解的方式进行查找表名以及指定列名 也可以通过扫描配置文件(*.hbm.xml)进行获取表名以及指定列名
测试:
//获取指定列名
Class clz=Class.forName("com.escs.entity."+"res_00201".toUpperCase());
System.out.println(EntityUtil.getColumnName(clz,0));
还没有评论,来说两句吧...