我有一个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_’.
谢谢你的时间!