gpt4 book ai didi

c# - 需要领域建模建议——希望是常见的场景

转载 作者:行者123 更新时间:2023-11-30 22:39:55 25 4
gpt4 key购买 nike

提前感谢您的宝贵时间。

我们使用的是 CSLA 3.5.1,尽管最终这个问题可能与 CSLA 没有太大关系。

我的公司在常见建模错误的道路上走了很长一段路,最终不得不面对它。我简化了以下域对象以阐明问题:

我们定义了 3 个类:

人类:BusinessBase

类(class)学生:人

类主任:人

我们将 NHibernate 用于我们的 ORM,并且 Student 和 Teacher 类在我们的映射中加入了 Person 的子类(我们有 Person、Student 和 Teacher 表),使用 PersonID 作为派生键。

正如您可能预料到的那样,问题是现在我们遇到了学生也可以是老师的情况。在当前的对象和数据模型下,当我们尝试添加已经是教师的学生时,这会导致主键冲突,反之亦然。

问题一:在保存新记录之前,我可以对业务对象执行任何 CSLA 魔法来防止这种情况发生吗?

如果不是...

在研究这个问题时,我看到了两个解决它的建议,第一个是支持组合而不是继承。据我了解,这意味着 Student 和 Teacher 将各自包含一个 Person 属性。

问题二:为了让它工作,假设 Student 和 Teacher 表需要一个外键到 Person 表中是否正确?我想我对这个解决方案没有完全的了解,希望得到一些指导。

第二种解决方案涉及将学生和教师视为给定人员所扮演的角色。据我所知,Person 类需要一个 Roles 集合,并且链接表(PersonRoles?)用于将 Student 和 Teacher 表中的记录映射到 Person。

问题三:Role基类和PersonRoles表是什么样的?我相信 Student 和 Teacher 子类只会包含它们适当的属性。这是正确的吗?

对解决方案有什么意见吗?如果有人能在网上找到充实的示例,我很乐意看到它。

谢谢,

将.

最佳答案

问题 1:据我所知不是。这没什么好说的;我没有使用过 CSLA,但我认为这是 NHibernate 的事情,必须用 NHibernate 来解决。

问题 2:是的,概念上。一个人有零到一个学生和零到一个老师,但所有学生和老师都需要一个人引用。我为此使用 Fluent NHibernate,因此您必须查找等效的 HBM 语法,但是:

public class PersonMap:ClassMap<Person>
{
public PersonMap()
{
Table("Person");
Id(x=>Id).Column("PersonID");
References(x=>x.Student).KeyColumn("StudentID")
Nullable().Cascade.All();
References(x=>x.Teacher).KeyColumn("TeacherID")
Nullable.Cascade.All();
}
}


public class TeacherMap:ClassMap<Teacher>
{
public TeacherMap()
{
Table("Teacher");
Id(x=>Id).Column("TeacherID");
References(x=>x.Person).KeyColumn("PersonID")
.Not.Nullable().Cascade.None();
}
}

public class StudentMap:ClassMap<Student>
{
public StudentMap()
{
Table("Student");
Id(x=>Id).Column("StudentID");
References(x=>x.Person).KeyColumn("PersonID")
.Not.Nullable().Cascade.None();
}
}

现在,Person 是这个对象图的顶点;您可以检索人员、学生或教师,但在保存更改时,始终保存人员,并且该人员的子角色也将保留。

关于c# - 需要领域建模建议——希望是常见的场景,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5461564/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com