Symfony2 应用程序通常有一个实体集合。DoctrineEntityManager
通常用于获取和持久化这些实体。
实体在整个应用程序的多个地方使用;对于许多实体和每个实体,将给定实体的处理加上获取/持久化服务包起来是有意义的。
例如,对于一个User
实体,可能有一个UserService
withfetchUser($user_id)
和persistUser(User $user)
方法(或者可能只是fetch()
and persist(
)方法,这只是一个示例)。
一个应用程序可以最终获得许多面向实体的服务,用于获取和持久化实体。此类服务的接口相似,处理的实体类型不同。
一个应用程序可以包含许多面向实体的服务似乎很常见。因此,命名和架构此类服务的问题是一个常见问题。
例如,对于一个需要创建 baseEntityService
和 child的新应用程序UserService
,WidgetService
类ProductService
感觉是重复的,因为处理这些方面的方法应该是一个已解决的问题。
是否有将此类实体管理相关服务引入 Symfony 应用程序的最佳实践?
这感觉它应该是一个已解决的问题,可能需要遵循一个成熟的设计模式。
是否有建议遵循的命名约定?
我观察到,在不同的应用程序中,`UserManager` 和 `UserService` 都被选为服务名称。有通行的约定吗?