加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 在hibernate统计中,load和fetch之间有什么区别?

发布时间:2020-12-14 05:15:16 所属栏目:Java 来源:网络整理
导读:我主要看EntityStatics( http://www.hibernate.org/hib_docs/v3/api/org/hibernate/stat/EntityStatistics.html).我可以看到很多的抓取,加载和更新,我无法找到任何地方说它们之间有什么区别. 解决方法 通过代码工作,当从数据源检索实体(而不是任何高速缓存)
我主要看EntityStatics( http://www.hibernate.org/hib_docs/v3/api/org/hibernate/stat/EntityStatistics.html).我可以看到很多的抓取,加载和更新,我无法找到任何地方说它们之间有什么区别.

解决方法

通过代码工作,当从数据源检索实体(而不是任何高速缓存)时,提取计数器才会递增 –
protected Object loadFromDatasource(
        final LoadEvent event,final EntityPersister persister,final EntityKey keyToLoad,final LoadEventListener.LoadType options) {
    final SessionImplementor source = event.getSession();
    Object entity = persister.load(
            event.getEntityId(),event.getInstanceToLoad(),event.getLockMode(),source
    );

    if ( event.isAssociationFetch() && source.getFactory().getStatistics().isStatisticsEnabled() ) {
        source.getFactory().getStatisticsImplementor().fetchEntity( event.getEntityClassName() );
    }

    return entity;
}

负载计数器从太多的地方被调用,以全部跟踪它们,但是它看起来像在实体加载时增加,无论是从数据源还是缓存.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读