一个最简单的JPA查询语句。hibernate4.0支持的JPA版本。在数据库执行原生SQL只要5ms在JPA entityManager里用query执行JPQL却需要400MS左右。我也是醉了。没法玩了JPA。求大神给答案
1条回答 默认 最新
- fnkfdn 2016-05-12 12:24关注
Hibernate 处理 ManyToOne OneToOne的时候,default是Eager Fetch,导致取下来是整颗对象树,本以为是限制取的层数,实际发现不是,这个只是限制用JOIN连接表的层数,如果超过这么多层,下面的会另外生成SQL语句去取,直到完整一棵对象树取完,大量的SQL语句导致效率及其低下,域模型越复杂效率越低!
解决方式:ManyToOne OneToOne 都用lazy fetch,当需要使用lazy对象的时候,left join fetch 之。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥25 关于##爬虫##的问题,如何解决?:
- ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
- ¥15 找一位技术过硬的游戏pj程序员
- ¥15 matlab生成电测深三层曲线模型代码
- ¥50 随机森林与房贷信用风险模型
- ¥50 buildozer打包kivy app失败
- ¥30 在vs2022里运行python代码
- ¥15 不同尺寸货物如何寻找合适的包装箱型谱
- ¥15 求解 yolo算法问题
- ¥15 虚拟机打包apk出现错误