假设我正在为一家制药公司开发一个软件,其中每个'ProductionLine'
都有多个'Stages'
,每个阶段都有多个'Machines'
现在假设我正在维护三个表来记录阶段及其机器(将生产线留在讨论中)。
(1) 阶段(代表任何生产线可能具有的所有可能阶段的基本数据)
(2) 机器(代表生产工厂可以拥有的所有可能机器的基本数据)
(3) StageMachines(表示为一个阶段分配的机器数量)
请注意,一个阶段可以有多台机器,一台机器可以是多个阶段的一部分。但是机器类不应该有阶段列表,因为它与业务问题域无关。
我设计了以下课程:
public class Stage
{
private int _stageId;
public int StageID
{
get { return _stageId; }
set { _stageId = value; }
}
private string _stageName;
public string StageName
{
get { return _stageName; }
set { _stageName = value; }
}
private List<Machine> myVar;
public List<Machine> Machines
{
get { return myVar; }
set { myVar = value; }
}
public static bool Save(Stage stage)
{
//save code goes here...
}
}
public class Machine
{
private int _machineId;
public int MachineID
{
get { return _machineId; }
set { _machineId = value; }
}
private string _machineName;
public string MachineName
{
get { return _machineName; }
set { _machineName = value; }
}
public Machine()
{
}
public Machine(int id, string name)
{
_machineId = id;
_machineName = name;
}
}
现在我面临一个困境:
(1) 当我创建一个舞台时,我必须从所有机器中选择一些机器并保存数据。我应该如何在我的代码中处理这个问题,因为我应该能够编写以下代码:
Stage s = new Stage();
s.Machines.Add(new Machine(1, "Machine#1"));
s.Machines.Add(new Machine(2, "Machine#2"));
s.Machines.Add(new Machine(3, "Machine#3"));
Stage.Save(s);
(2) 我应该如何在我的代码中维护这种多对多的关系?我应该创建一个名为的第三类'StageMachine'
吗?如果这样做,在创建 Stage 对象时应该如何保存机器?
谁能给我一个解决方案?
*** 另一个问题是,在检索阶段的机器时,我应该如何以及在 nTier 中的何处进行映射?
此链接讨论了类设计问题,但没有回答 NTier 设计中我的 Stage 对象的 Machines 的保存和检索机制。