hibernate 直接通过表名,获取字段名及字段类型??

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hibernate 直接通过表名,获取字段名及字段类型??相关的知识,希望对你有一定的参考价值。

hibernate是一个orm面向对象操作的框架,将表映射成一个PO实体类,表的字段映射为PO的字段,表的每一条记录映射为PO的实例。 但是hibernate也是支持原生态的SQL,也是可以通过select t.name from T_User t where t.id = ? 这种方式获取结果 参考技术A /**
* 功能描述:根据实体类得到对应的表名、主键名、字段名工具类
* </p>
* 注:po类名须与对应映射文件名一致,即Student.java与Student.hbm.xml
*
* @Date:Nov 10, 2008
* @Time:3:13:07 PM
*
*/
public class HibernateConfigurationHelper
private static Configuration hibernateConf;
@SuppressWarnings("unused")
private static Configuration getHibernateConf()
if (hibernateConf == null)
return new Configuration();

return hibernateConf;

@SuppressWarnings("unchecked")
private static PersistentClass getPersistentClass(Class clazz)
synchronized (HibernateConfigurationHelper.class)
PersistentClass pc = getHibernateConf().getClassMapping(
clazz.getName());
if (pc == null)
hibernateConf = getHibernateConf().addClass(clazz);
pc = getHibernateConf().getClassMapping(clazz.getName());

return pc;


/**
* 功能描述:获取实体对应的表名
*
* @param clazz
* 实体类
* @return 表名
*/
@SuppressWarnings("unchecked")
public static String getTableName(Class clazz)
return getPersistentClass(clazz).getTable().getName();

/**
* 功能描述:获取实体对应表的主键字段名称
*
* @param clazz
* 实体类
* @return 主键字段名称
*/
@SuppressWarnings("unchecked")
public static String getPkColumnName(Class clazz)
return getPersistentClass(clazz).getTable().getPrimaryKey()
.getColumn(0).getName();

/**
* 功能描述:通过实体类和属性,获取实体类属性对应的表字段名称
*
* @param clazz
* 实体类
* @param propertyName
* 属性名称
* @return 字段名称
*/
@SuppressWarnings("unchecked")
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;

/**
* @param args
*/
public static void main(String[] args)
System.out.println(getTableName(IntelligenceNetVPNAndSCP.class));
System.out.println(getColumnName(IntelligenceNetVPNAndSCP.class,
"vsCode"));

参考技术B hibernate是将数据库中的表与类进行关联的OR Mapping映射,将数据库中的表映射到实体类中了。 参考技术C 不是表名,映射过来的类名, 参考技术D hibernate 没有表名的概念 只有类名的概念

以上是关于hibernate 直接通过表名,获取字段名及字段类型??的主要内容,如果未能解决你的问题,请参考以下文章

SQLServer 获得所有表结构(包括表名及字段)

django中自定义表名及字段名称

sql server2008如何查询在指定的数据库中所有的表名和每个表的字段名及字段类型

数据库小记:根据指定名称查询数据库表名及根据指定名称查询数据库所有表中的字段名称(支持mysql/postgre)

反射判断对象所有字段是空及获取对象字段名及字段值

hibernate配置文件怎么修改才能使表名、字段名区分大小写