一尘不染

延迟加载的MVC

hibernate

如果这是完全相同的内容,请纠正我,我知道这个话题经常被讨论,但是找不到确切的答案。

问题:

在MVC Web应用程序中处理Hibernate对象的最佳实用解决方案是什么?

细节:

我正在使用Hibernate,并希望在可能的情况下利用延迟加载。
我正在使用MVC风格的Webapp。
我讨厌获得延迟加载初始化异常。
我讨厌不得不在事务之间重新连接Hibernate对象。

选项:

  1. 渴望装载一切
    • 解决了懒惰的初始化问题,但使查询更大
  2. 使用一些“在视图中打开会话”的概念
    • 我喜欢它的简单性
    • 仍然需要重新附加对象,并且在AJAXy设置中,经常
    • 为每个请求打开一个会话
  3. 离开交易前我需要“触摸”物品
    • 充其量似乎很脆弱。
  4. 创建不同的,简化的“分离”对象,以便视图永远看不到真正的Hibernate对象
    • 这些可能比完整的Hibernate对象要简单,所以它不像是一个完整的模型
    • 我听说过此建议,但似乎更多的责任/代码/工作
  5. 当我想与Hibernate对象进行交互时,打开一个会话。
    • 可以很好地将其包装在Spring Service层中,但有时似乎过多。例如:我想要hibernateObject.getRelatedObjects()但需要说些类似的话springService.getRelatedObjects(hibernateObject)

我想念什么吗?
我是否考虑得太多了?
我是否思想不足?

PS:

对于Web框架,我正在使用ZK,但实际上 并不 需要ZK特定的答案。
我也使用Spring,并且对Spring的特定回答很酷,因为它无处不在。


阅读 260

收藏
2020-06-20

共1个答案

一尘不染

使用4-ish-
不要在视图中使用开放会话,不要让您的hibernate实体一直冒泡到视图,而是要让转换器在hibernate实体和域对象或“视图bean”之间转换,具体取决于您想要工作。

我认为Hibernate实体只是一种持久策略,而不是域模型或UI表示。

2020-06-20