加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-14 16:18:17 所属栏目:Java 来源:网络整理
导读:我有一个Person类,它有一个字符串集合的别名,表示人们可能去的附加名称.例如,克拉克肯特可能会有别名“超人”和“钢之人”.德怀特霍华德也有一个“超人”的别名. @Entityclass Person { @CollectionOfElements(fetch=FetchType.EAGER) SetString aliases = n
我有一个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)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读