Hql以关联对象的某一属性来进行查询?

hxhazx 2014-06-18 11:42:14
主要是有这么个需求:

现有两个对象:1、订单对象Orders 2、用户对象Client
两者是Order(n) ----- Client(1) 多对一关系

在保存订单时,
1、如果订单归属于某一用户,则进行关联(表现到数据库中就是订单表中该条记录有外键且指向一个用户主键),字段为oneClient;
2、如果无归属关系,则不关联(表现到数据库中订单表中该条记录外键为null);但会在另外一个字段(如clientName)中存入一个用户名(单纯String)

现在我要对订单进行查询 ,想要的效果是,我给出一个用户名(如:XXX),如果订单关联了用户对象,且该用户对象的name等于XXX,则此订单符合查询要求;若无关联用户对象,则比较XXX与clientName是否相同,同则也条例查询要求

现在这个hql不会写了,现在只写成这样:
from Orders t where t.oneClient.name=XXX or t.clientName=XXX;
但一旦使用t.oneClient,即将两张以外键关系进行了表连接,这样连接后的大表直接就将无关联Client的订单记录过滤掉了,那上面提到的保存时第2个查询要求的记录就完全查不出来了。

如上此问题怎么解决呢?hql该怎么写!
...全文
650 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
loveunittesting 2014-06-18
  • 打赏
  • 举报
回复
对,就是用left join解决
xinlan1022 2014-06-18
  • 打赏
  • 举报
回复
hql也可以left join的吧
XiZhuXi 2014-06-18
  • 打赏
  • 举报
回复
select t from Orders t left join t.sendClient sc left join t.acceptClient ac where t.available=1 and (t.members.id=? or t.acceptmemb.id=?) and ( ac.clientname like ? or t.acceptCompany like ? ) and ( t.sendCompany like ? or sc.clientname like ? or t.members.membName like ?) order by t.createdAt desc
hxhazx 2014-06-18
  • 打赏
  • 举报
回复
引用 2 楼 yys79 的回复:
对,就是用left join解决
一般常规的用法格式是怎样的呢,我现在要左连接三张表啊 比如:from Orders t left join Client c1 left join Client c2 或者 :from Orders t left join t.sendClient sc left join t.acceptClient ac [注:sendClient、acceptClient都是Orders中关联的属性名] 哪个正确呢,我正在试验,如果大神知道,不防直接告诉小弟

67,538

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧