Hql以关联对象的某一属性来进行查询?
主要是有这么个需求:
现有两个对象: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该怎么写!