4

我即将开始创建一个新应用程序,并希望获得有关我计划使用的方法的一些反馈。我们将使用 spring 和 spring data jpa。

  1. 控制器是否可以调用域服务和存储库,或者控制器是否应该只调用应用程序和基础设施服务?

  2. 如果从控制器调用域服务和存储库“可以”并且域服务操作需要事务,我可以/应该将@Transactional 注释放在域服务方法上吗?或者我应该有一个包装调用的应用程序服务(不确定我是否喜欢这种方法,因为你最终会得到一堆传递方法)?

  3. 如果从控制器调用域服务和存储库不是“可以”,我是否需要创建应用程序服务来包装所有可能的域服务调用(就像我在 2 中所说的那样,这可能是很多传递方法)?

我能想出的最佳解决方案如下:

  1. 存储库将具有 @Transactional 注释,在写入数据库时​​需要传播,传播设置为 readOnly=true,从数据库读取时传播设置为 SUPPORTS。

  2. 应用程序和域服务将根据需要添加 @Transactional 注释

如果控制器需要直接调用存储库、域服务或应用程序服务,它可以。没有穿越。

在此处输入图像描述

4

2 回答 2

0

我不清楚你的问题。域服务在做什么?我非常了解应用程序服务和域存储库。

在 spring 中,有两层服务和数据访问层。服务层可以使用@Service(在您的设计中它将是应用程序服务)但不能使用@Transactional Tag。

数据访问层使用了@Repository Tag,也使用了@Transactional Tag,因为这层是直接连接到数据库进行操作的。所以,我想知道域服务的功能是什么。我不清楚这一点。

谢谢哥们。

于 2013-09-10T09:32:34.957 回答
0

我个人只会从您的控制器访问您的域和应用程序服务。这样,您只需将@Transactional注释放在一个“级别”上。如果您正在扩展常规 Spring Data 存储库接口,您可以在存储库层获得开箱即用的事务性。我会尽可能简单地保留该层。将您readOnly和其他配置放在服务层。

如果您决定更改您的 DAO 实现,创建“通过”方法也可以让您更加灵活。

于 2014-02-02T16:34:53.603 回答