ssh延迟加载问题的解决方案
2024-09-01 04:31:39
1. 什么是延迟加载问题 ?
业务层查询的数据 关闭session 之后...web层获取延迟加载的数据失败.
例如:查询订单没有查询客户,需要显示客户,session已经关闭,无法查询
2. 如何解决延迟加载问题
方案一: 将订单关联客户,配置成为 立即加载 lazy=false
方案二: 在业务层,session关闭前,通过Hibernate.initialize(object) 手动对延迟对象初始化
Hibernate.initialize(list.get(0).getStores());//立刻查询数据库,查询stores
方案三: OpenSessionInView 将session开放到表现层
Spring 提供了 OpenSessionInViewFilter ,在执行表现层方法前,开启Session, 在表现层方法执行后,关闭Session ---------------- 服务器三层都可以使用同一个Session
注意: 必须在struts2 Filter之前配置才能有效 !!!
3.如何选用延迟加载的方法?
如果不需要延迟加载的数据,那么建议使用第一种方法;
如果需要延迟加载的数据,选择第二、第三种方法。
第二种方法与第三种方法简要区别:
第二种方法:当执行Hibernate.initialize(object) 方法时,立即查询数据库,没有改变session的生命周期。
第三种方法:改变了session的生命周期,将业务层的session生命周期延长到表现层,从而获得延迟加载的数据。
最新文章
- a标签产生间隙,<;a>; 包裹 <;img>; 产生 4px 间隙
- ASP.NET MVC URL重写与优化(进阶篇)-继承RouteBase玩转URL
- KDE、GNOME 和 XFCE 桌面比较
- 九张图让你的PPT立刻高大上
- runas /user:administrator cmd 以管理员身份运行CMD
- 转:什么是FOUC?如何避免FOUC?
- 安装Microsoft .NET Framework 3.5 Service Pack 1回报1603错
- 解锁redis锁的正确姿势
- form提交地址地址正确但是依旧报错404找不到路径
- [poj1185]炮兵阵地_状压dp
- jdbc连接mysql加载驱动程序com.mysql.jdbc.Driver
- JS的事件流的概念(重点)
- Maven教程1(介绍安装和配置)
- brctl创建虚拟网卡详解
- BZOJ.2034.[2009国家集训队]最大收益(二分图匹配 贪心)
- Java中JSONObject相关操作
- mysql 导入csv文件
- Linux下端口被占用确认
- sell 创建项目
- Atitit 大龄软件工程师的出路attilax总结