今天遇到一个非常奇怪的问题,mysql数据库,hibernate注解配置表,from Wxyhdtb where zt=1 and wxyh.id=1 order by wxyh.id
测试发现在where条件中wxyh.id会出错,Unknown column 'wxyh.id' in 'where clause',
但是只在order by wxyh.id
却没有问题 ,请问这是什么情况?
注:以前用oracle 就不会出现这种情况
from Wxyhdtb where zt=1 and wxyh.id=1 order by wxyh.id
HQL语句面向的是对象bean. 虽然看起来很想SQL,但其实是对象。 因此对于你的这条HQL语句。 Wxyhdtb应对应类,同时where 后的字段对应的应该是Wxyhdtb对象的属性。看你的HQL where条件,Wxyhdtb 应该 和 wxyh 对应的对想是有关联的。 wxyh应该对应另一个表的。
针对
from Wxyhdtb where zt=1 and wxyh.id=1 order by wxyh.id
这条HQL语句,你的实体bean可能如下结构
@Entity
@Table(name = "tb_a")
class Wxyhdtb{
@Id
Long id;
Integer zt ;
@OneToOne // 也有可能是 ManyToOne
Wxyh wxyh;
}
@
Entity
@Table(name = "tb_b")
class Wxyh {
@Id
Long id;
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。