我正在使用 hibernate 的Criteria
类来获取table的所有记录:
Criteria criteria = session.createCriteria(AppTaskConfig.class)
我也想获取列名,因为我需要将结果集转换为JSON格式。
最佳答案
要获取column names
,首先需要使用properties
查找实体的org.hibernate.metadata.ClassMetadata
:
ClassMetadata classMetadata = sessionFactory.getClassMetadata(AppTaskConfig.class);
String[] propertyNames = classMetadata.getPropertyNames();
其中
propertyNames
是一个字符串数组,表示AppTaskConfig
的属性名称。现在使用Hibernate
org.hibernate.cfg.Configuration
对象,您可以找到properties
的列名:for (String property : propertyNames) {
Configuration configuration = sessionFactoryBean.getConfiguration();
PersistentClass persistentClass = configuration
.getClassMapping(Details.class.getName());
String columnName = ((Column) persistentClass.getProperty(property)
.getColumnIterator().next()).getName();
}