sql创建person表JAVA_java – 可以获取Hibernate sqlRestriction的连接表的SQL别名吗?

我有一个Person类,它有一个字符串集合的别名,表示人们可能去的附加名称.例如,克拉克肯特可能会有别名“超人”和“钢之人”.德怀特霍华德也有一个“超人”的别名.

@Entity

class Person {

@CollectionOfElements(fetch=FetchType.EAGER)

Set aliases = new TreeSet();

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_’.

谢谢你的时间!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值