hibernate 获取实体的表名、主键名、列名(转载+修改)

分手后的思念是犯贱 2022-06-15 07:18 405阅读 0赞
  1. package com.escs.utils;
  2. import java.util.Iterator;
  3. import org.hibernate.cfg.AnnotationConfiguration;
  4. import org.hibernate.cfg.Configuration;
  5. import org.hibernate.mapping.Column;
  6. import org.hibernate.mapping.PersistentClass;
  7. import org.hibernate.mapping.PrimaryKey;
  8. import org.hibernate.mapping.Property;
  9. /**
  10. * 功能描述:根据实体类得到对应的表名、主键名、字段名工具类
  11. * </p>
  12. * 注:po类名须与对应映射文件名一致,即Student.java与Student.hbm.xml<br>
  13. * //修改为主注解方式,此hbm文件已经不需要
  14. *
  15. *
  16. * @Date:Nov 10, 2008
  17. * @Time:3:13:07 PM
  18. *
  19. */
  20. public class EntityUtil {
  21. private static Configuration hibernateConf;
  22. private static Configuration getHibernateConf() {
  23. if (hibernateConf == null) {
  24. hibernateConf=new Configuration();//*.hbm.xml方式
  25. // hibernateConf=new AnnotationConfiguration().configure();//注解方式
  26. // hibernateConf.buildSessionFactory();//注解方式必须的
  27. }
  28. return hibernateConf;
  29. }
  30. private static PersistentClass getPersistentClass(Class<?> clazz) {
  31. synchronized (EntityUtil.class) {
  32. PersistentClass pc = getHibernateConf().getClassMapping(
  33. clazz.getName());
  34. if (pc == null) {
  35. hibernateConf = getHibernateConf().addClass(clazz);//*.hbm.xml方式 注解方式去掉这个
  36. pc = getHibernateConf().getClassMapping(clazz.getName());
  37. }
  38. return pc;
  39. }
  40. }
  41. /**
  42. * 功能描述:获取实体对应的表名
  43. *
  44. * @param clazz
  45. * 实体类
  46. * @return 表名
  47. */
  48. public static String getTableName(Class<?> clazz) {
  49. return getPersistentClass(clazz).getTable().getName();
  50. }
  51. /**
  52. * 获取指定列的列名
  53. * @param clazz
  54. * @param num
  55. * @return
  56. */
  57. public static String getColumnName(Class<?> clazz,int num) {
  58. return getPersistentClass(clazz).getTable().getColumn(num).getName();
  59. }
  60. /**
  61. * 功能描述:获取实体对应表的主键字段名称,只适用于唯一主键的情况
  62. *
  63. * @param clazz
  64. * 实体类
  65. * @return 主键字段名称
  66. */
  67. public static String getPrimaryKey(Class<?> clazz) {
  68. return getPrimaryKeys(clazz).getColumn(0).getName();
  69. }
  70. /**
  71. * 功能描述:获取实体对应表的主键字段名称
  72. *
  73. * @param clazz
  74. * 实体类
  75. * @return 主键对象primaryKey ,可用primaryKey.getColumn(i).getName()
  76. */
  77. public static PrimaryKey getPrimaryKeys(Class<?> clazz) {
  78. return getPersistentClass(clazz).getTable().getPrimaryKey();
  79. }
  80. /**
  81. * 功能描述:通过实体类和属性,获取实体类属性对应的表字段名称
  82. *
  83. * @param clazz
  84. * 实体类
  85. * @param propertyName
  86. * 属性名称
  87. * @return 字段名称
  88. */
  89. public static String getColumnName(Class<?> clazz, String propertyName) {
  90. PersistentClass persistentClass = getPersistentClass(clazz);
  91. Property property = persistentClass.getProperty(propertyName);
  92. Iterator<?> it = property.getColumnIterator();
  93. if (it.hasNext()) {
  94. Column column = (Column) it.next();
  95. return column.getName();
  96. }
  97. return null;
  98. }
  99. }

上述方法可以用个扫描注解的方式进行查找表名以及指定列名 也可以通过扫描配置文件(*.hbm.xml)进行获取表名以及指定列名

测试:

  1. //获取指定列名
  2. Class clz=Class.forName("com.escs.entity."+"res_00201".toUpperCase());
  3. System.out.println(EntityUtil.getColumnName(clz,0));

发表评论

表情:
评论列表 (有 0 条评论,405人围观)

还没有评论,来说两句吧...

相关阅读