我有以下实体类:
@Entity
@FilterDef (name = "byLastName", parameters = @Parameter (name = "lastName", type="string"))
@Filters ({
@Filter (name = "byLastName", condition = "lastName = :lastName")
})
public class User {
String firstName;
String lastName;
}
在我的DAO中,我这样做:
public User findById (Long id)
{
Session s = (Session) em.getDelegate ( );
s.enableFilter ("byLastName").setParameter ("lastName", "smith");
User u = em.find (User.class, id);
return (u);
}
现在,如果我理解正确的话,应该应用过滤器,如果lastName不等于"smith",那么任何我尝试检索的用户都应该返回null。问题是过滤器似乎没有应用。无论lastName的值如何,我尝试从数据库检索的任何用户都会返回。
我是否误解了过滤器的工作原理?或者我在配置上漏掉了什么吗?请注意,我没有使用hibernate.cfg.xml;一切都是使用JPA和注释为我配置的。
非常感谢任何帮助。
谢谢。