4

我在两个对象之间有 OneToMany/ManyToOne 关系,例如:

public class Company {
    private Long compid;
    private String companyName;

    @OneToMany(mappedBy = "company", cascade = CascadeType.ALL)
    @LazyCollection(LazyCollectionOption.FALSE)
    private List<Employee> employees;
}

public class Employee {
    private Long empid;
    private String fstName;
    private String lstName;
    private String sal;

    @ManyToOne(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
    @NotFound(action = NotFoundAction.IGNORE)
    @JoinColumn(name = "compid", nullable = true)
    private Company company;
}

我想得到拥有company.companyName like xxxx%. 我试过类似的东西:

Criteria criteria = session.createCriteria(Employee.class);
criteria.createAlias("company", "company");
criteria.add(Restrictions.like("company.companyName ", "xxxx%"));
return criteria.list();

但我得到错误:

could not resolve property: company.companyName of: Employee

这段代码的问题在哪里?

4

3 回答 3

1

你应该使用criteria.createCriteria而不是criteria.createAlias

于 2012-10-15T15:09:24.040 回答
1

您已经添加了一个空格,例如"company.companyName "在第 3 行标准中。是错字吗?如果不是,那么它就是问题的原因。

于 2012-10-15T16:20:18.307 回答
1

我找到了问题的根源,这是我的一个愚蠢的错误,在我的原始代码中我输入了 compny.companyName,我忘记了公司中的“a”,它工作得很好。

于 2012-10-16T06:17:17.803 回答