同样,基于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;
}