【发布时间】:2010-02-18 11:05:15
【问题描述】:
我和我的团队正在开发一个包含许多模块(人力资源、会计等)的 ERP 系统
我们面临的问题是两个模块(人力资源、会计)之间存在一些共享实体,比如员工
人力资源系统中的员工有很多细节,例如:
Personal Information , Visa Info , Report To , Sources , Training , Etc
会计员工的信息很少
Personal Information , Bank Account , Employee Account (That's it )
1)假设每个模块都将作为独立版本工作(此完成)
2)假设两个模块一起工作,这意味着员工将反映在两个模块中,即使他们在每个系统中有不同的流程
当我在 HR 模块中定义一个新员工时,我需要什么让会计模块感受到变化以及两个模块中发生的任何操作,它们必须处理同一个实体??
考虑到该员工与其他实体有关,例如与他相关的公司,并且该公司实体在两个模块中都不同(例如,它在 HR 模块中有很多细节,但在会计中只有公司有一些它下面的分支)
注意:每个模块都有单独的数据库(不想在独立版本中扩大数据库)
开发两个模块以协同工作的正确方法是什么?还是作为独立的???
是不是太晚了,我们应该从一开始就将它设计为共享实体?
如果我使用共享实体意味着我应该共享业务逻辑和数据访问层?
我尝试在谷歌上搜索很多关于此的信息,但此类信息仅来自实际实施和生活经验
技术: Asp.net + Mysql
【问题讨论】:
标签: integration erp