我正在使用 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();
}

10-01 13:35