0

使用 Hibernate 3.6.8.Final 和 Spring 3.0.5.RELEASE ,我正在尝试为具有多个实现的类添加一些 Common DAO 功能,这些实现被重写以实现特定的类,但它不适用于 DetachedCriteria。

例子:

在基类中:

public interface ICat {
    public void setMeowSound(String meow);
    public String getMeowSound();
}

然后每个继承的项目将定义休眠注释。

例如

@Entity
@Table(name="SQUAWKY_CATS")
public class SquawkyMeowingCat implements ICat, Serializable {
    @Id
    @Column(name="SQUAWK_NAME")
    private String meow;

    public String getMeowSound() {
        return meow;
    }

    public void setMeowString(String meow) {
        this.meow = meow;
    }
}

这意味着我可以使用:

Criteria criteria = Session.createCriteria(ICat.class);

Spring/Hibernate 知道它从特定项目中的具体继承中提取 ICat 的注释。

但是,如果我尝试这样做:

DetachedCriteria subQuery = DetachedCriteria.forClass(ICat.class,"inner"); // etcetera

然后我在运行时为 ICat 获得一个未知实体。

现在这是有道理的,因为在第一个实例中是从 Session 中创建它,因此它具有所需的所有配置,而 DetachedCriteria 是一个静态方法,但是在尝试执行

criteria.list()

到那时它已经拿起了 Session 并且应该知道 ICat 实际上是一个 SquawkyMeowingCat ,它具有所有的注释。

所以我的问题分为两部分:

1)这是已知的行为,并且会永远这样吗?

2) 谁能想到一个简单的方法而不使用接口和具体的 ClassHolder 来交还它需要创建的类的实例?

4

1 回答 1

0

我不确定 DetachedCriteria 的情况,但避免显式依赖具体类的一种方法可能是使用接口查询 Hibernate 的元数据:

public <T> Class<? extends T> findEntityClassForEntityInterface(
    SessionFactory sessionFactory, 
    Class<T> entityInterface
) {
    for (ClassMetadata metadata : sessionFactory.getAllClassMetadata().values()) {
        Class entityClass = metadata.getMappedClass(EntityMode.POJO);
        if (entityInterface.isAssignableFrom(entityClass)) {
            return entityClass;
        }
    }
    return null;
}

关于说明性代码片段的健壮性的常见警告。

于 2012-01-05T15:05:25.137 回答