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));