iteye_14486 2011-03-14 17:16
浏览 177
已采纳

基础问题 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操作呢

  • 写回答

1条回答 默认 最新

  • redstarofsleep 2011-03-14 18:59
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里