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 C++使用Gunplot
  • ¥15 这个电路是如何实现路灯控制器的,原理是什么,怎么求解灯亮起后熄灭的时间如图?
  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 file converter 转换格式失败 报错 Error marking filters as finished,如何解决?
  • ¥15 Arcgis相交分析无法绘制一个或多个图形
  • ¥15 关于#r语言#的问题:差异分析前数据准备,报错Error in data[, sampleName1] : subscript out of bounds请问怎么解决呀以下是全部代码:
  • ¥15 seatunnel-web使用SQL组件时候后台报错,无法找到表格
  • ¥15 fpga自动售货机数码管(相关搜索:数字时钟)