• 转:hibernate中的N+1问题


    什么时候会出现N+1问题?

          在hibernate中,当进行一个表的查询时,当这个表与另外的表是多对一,或者是一对多关联时,就会出现N+1问题,当查询一条语句时,比如主键name=1,而与这个name相关联的另一张表对应name的有N个记录,这时就出另外发出N条语句去查询,而我又不要那些记录,这时就是N+1问题。

    解决方法:

    1.设置lazy=true;

    2.在本类DTO中有关联另外表的表对象的声明,在他的get方法上面加上一个@fetch=fetchtype.lazy;

    3.在关联的类上面设置@batchsize=2;这时就只发出两条语句。

    4.用SQL来查询,写SQL语句时就写成联合查询的形式。

  • 相关阅读:
    Spring MVC(一)
    Spring-IOC总结
    IT
    Spring基础
    Maven
    Ajax笔记
    数据库和SQL语言
    JDBC
    拦截器
    文件上传
  • 原文地址:https://www.cnblogs.com/phoebus0501/p/1885662.html
Copyright © 2020-2023  润新知