我面临异常:org.hibernate.hql.ast.QuerySyntaxException:未映射Student6(来自Student6螺栓)
我的表名是sql server数据库中的Student6,而pojo类名是Student。
public static void main(String[] args) {
Configuration configuration = new Configuration();
SessionFactory sessionFactory = configuration.configure().buildSessionFactory();
Session session = sessionFactory.openSession();
try {
String SQL_QUERY ="from Student6 stud";
Query query = session.createQuery(SQL_QUERY);
for(Iterator it=query.iterate();it.hasNext();) {
Object[] row = (Object[]) it.next();
System.out.println("STUDENT_ID: " + row[0]);
System.out.println("STUDENT_NAME: " + row[1]);
System.out.println("ADDRESS_STREET: " + row[2]);
System.out.println("ADDRESS_CITY: " + row[3]);
System.out.println("ADDRESS_STATE: " + row[4]);
System.out.println("ADDRESS_ZIPCODE: " + row[5]); }
} catch (HibernateException e) {
transaction.rollback();
e.printStackTrace();
} finally {
session.close();
}
}
最佳答案
您的查询不是SQL查询。这是一个HQL查询。因此,它不应使用表名称,而应使用实体类名称(from Student
代替from Student6
)。而且它不会以Object[]
实例的形式返回行,而是会返回实体实例。
休眠是一个ORM:对象关系映射器。这个想法是使用对象而不是关系数据。您应该重新阅读Hibernate reference manual。