基础问题 hibernate的表连接意义所在

我是Hiberante新手,现在在学习时候遇到一个疑惑,既然hibernate可以双向关联两张表,比如student和class;student实体中有Class属性,Class实体中有student集合,疑问如下

//我想打印学生姓名,学号,所在班级:
Student s = session.createQuery("from Student s");
s.getSName();
s.getSNumber();
s.getClass.getClassName();

 这样不是可以代替sql语句的join关键词吗?那hibernate 怎么还用了join操作呢

是的,外建在Hibernate中配置了,就可以实现关联。但是你通过Hibernate生成的SQL语句可以发现,实际上是走了2条SQL语句的,这样会影响性能。况且,如果我只想查Student表的时候,你这样把关联的也查出来了。所以可以选择在配置文件中不配关联查询,特别是1对多的时候,多对多的时候(关联了以后一条HQL语句会生成N多条SQL语句。),不配置,关联,需要的时候自己去JOIN对性能会好很多。