java – 可以获取Hibernate sqlRestriction的连接表的SQL别名吗?

前端之家收集整理的这篇文章主要介绍了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)
原文链接:https://www.f2er.com/java/125886.html

猜你在找的Java相关文章