同样,基于a problem I had the other day为他人的利益发布和回答问题。希望这可以节省一些时间。我有点惊讶这不是JPA的EntityManager内置的。

如何确定实体是否具有带有特定名称的NamedQuery注释?

在尝试执行之前,我需要确定一个实体是否具有特定的@NamedQuery

最佳答案

当注释嵌套时,您可以获取注释的属性以获取其子级。对于@NamedQueries,它是.value()

public boolean hasNamedQuery(Class<?> clazz, String nameOfQuery) {
    boolean foundQueryByName = false;
    NamedQueries namedQueries = clazz.getAnnotation(NamedQueries.class);
    if (namedQueries != null && namedQueries.value() != null) {
        NamedQuery[] values = namedQueries.value();
        for (int i = 0; i < values.length && !foundQueryByName; i++) {
            foundQueryByName |= (nameOfQuery.equals(values[i].name()));
        }
    }
    return foundQueryByName;
}

10-06 12:18