java – 可以获取Hibernate sqlRestriction的连接表的SQL别名吗
我有一个Person类,它有一个字符串集合的别名,表示人们可能去的附加名称.例如,克拉克肯特可能会有别名“超人”和“钢之人”.德怀特霍华德也有一个“超人”的别名.
@Entity class Person { @CollectionOfElements(fetch=FetchType.EAGER) Set<String> aliases = new TreeSet<String>(); Hibernate在我的数据库Person和Person_aliases中创建两个表. Person_aliases是具有Person_id和element列的连接表.假设Person_aliases具有以下数据 -------------------------------- | Person_id | element | -------------------------------- | Clark Kent | Superman | | Clark Kent | Man of Steel | | Dwight Howard | Superman | | Bruce Wayne | Batman | -------------------------------- 我想为所有通过“超人”别名的人制定一个休眠标准. 由于在这里列出的原因太长了,我真的希望将其作为一个标准查询,而不是一个HQL查询(除非可以在Criteria对象上添加一个HQL限制,在这种情况下,我全部是耳朵) SQL查询.因为根据How do I query for objects with a value in a String collection using Hibernate Criteria?,不可能使用CriteriaAPI引用值类型集合的元素,我以为我会在我的标准对象上添加一个SqlRestriction. Criteria crit = session.createCriteria(Person.class); crit.add(Restrictions.sqlRestriction("XXXXX.element='superman'"); 希望Hibernate会创建一个SQL语句 select * from Person this_ left outer join Person_aliases aliases2_ on this_.id=aliases2_.Person_id where XXXXX.element='superman' 但是,我需要使用SQL查询中的Person_aliases表的表别名填写XXXXX,这将是“aliases2_”.我注意到,如果我需要引用Person表别名,我可以使用{alias}.但是这不会工作,因为Person是此条件的主表,而不是Person_aliases. 为XXXXX填写什么?如果没有像{alias}这样的好的变量符号,那么有没有办法让hibernate告诉我别名是什么?我注意到一个方法叫做generateAlias()org.hibernate.util.StringHelper类.这可以帮助我预测别名是什么吗? 我真的很想避免硬编码’aliases2_’. 谢谢你的时间! 解决方法
似乎Criteria API不允许查询元素的集合,请参阅
HHH-869(仍然是打开的).所以要么尝试建议的解决方法 – 我没有 – 或切换到HQL.以下HQL查询将工作:
from Person p where :alias in elements(p.aliases) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- java – Mockito Spy – stub在调用构造函数之前
- Java UDP通信:Java DatagramSocket类和DatagramPacket类
- java – 如何使用RESTlet在RESTful Web服务中强制执行“会话
- java – 从POJO访问EJB
- java – ThreadLocal上的操作是否必须同步?
- java – 在OGNL中使用Spring EL的好处?
- LinkedHashSet迭代时的java.util.ConcurrentModificationEx
- java – Log4J能够从磁盘恢复完整吗?
- jsoup爬虫--博客园首页爬取和图片爬取
- java并发编程之cas详解