【发布时间】:2019-09-30 00:51:21
【问题描述】:
我正在尝试从我使用 spring boot 和 hibernate 执行此项目的数据库中获取员工列表。 据我说,我做的一切都是正确的,但我得到了这个丑陋的例外
org.hibernate.hql.internal.ast.QuerySyntaxException: Employee is not mapped [from Employee];
我几乎尝试了互联网上的所有解决方案,有些人建议 POJO 名称和查询中使用的名称必须相同,我也这样做了。
@Entity
@Table(name="employee")
public class Employee {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name="id")
private int id;
@Column(name="first_name")
private String firstName;
@Column(name="last_name")
private String lastName;
@Column(name="email")
private String email;
public Employee() {
}
public Employee(String firstName, String lastName, String email) {
this.firstName = firstName;
this.lastName = lastName;
this.email = email;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
@Override
public String toString() {
return "Employee [id=" + id + ", firstName=" + firstName + ", lastName=" + lastName + ", email=" + email + "]";
}
}
@Repository
public class EmployeeDaoImpl implements EmployeeDao {
@Autowired
private EntityManager entity;
@Override
@Transactional
public List<Employee> ListAllEmployee() {
//create Session
Session session=entity.unwrap(Session.class);
Query<Employee> employee=session.createQuery("from Employee",Employee.class);
return employee.getResultList();
}
}
【问题讨论】:
-
如果是这种情况,你是否使用 mysql mysql 区分大小写 检查数据库中的表名是大写还是小写 stackoverflow.com/questions/6134006/…
-
你使用常规的打包方式(app在树的根部)吗?如果没有,请尝试@EntityScan
-
我使用了同一个名字,我的 pojo 名字是 Employee 并且在查询中也指的是同一个 Employee
-
感谢您的建议,我发现我的错误是包名中的拼写错误
标签: spring hibernate spring-boot