首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >fluent nHibernate映射

fluent nHibernate映射
EN

Stack Overflow用户
提问于 2008-12-27 21:28:26
回答 2查看 359关注 0票数 1

我正在开发一个遗留系统,并引入了fluent nHibernate,但我有最后一个映射似乎无法正常工作。

代码:

代码语言:javascript
复制
public class Permit
    {
    public int PermitId { get; set; }
    public char Discipline { get; set; }
    public PermitDetails PermitDetails { get; set; }
    }

public PermitDetails
    {
    public int PermitId { get; set; }
    }

public class GasPermitDetails : PermitDetails
    {
       ... permit details
    }

public class ElectricalPermitDetails : PermitDetails
    {
       ... permit details
    }

模式:

代码语言:javascript
复制
*tblPermit*
PermitId, int
Discipline, char
.... some other columns

*tblGas*
PermitId, int
....gasDetails

*tblElectrical*
PermitId, int
....electrical details

如果tblPermit.Discipline"G",我们需要从tblGas中获取数据。如果tblPermit.Discipline"E",我们需要从tblElectrical中获取数据。我到处乱搞,试图弄清楚这个问题,但到目前为止还没有任何运气。

EN

回答 2

Stack Overflow用户

发布于 2008-12-27 21:54:41

在我看来,模式是正确的。您可能需要更具体地说明您所遇到的问题,因为我认为所有PermitDetails子类的PermitId都变成了相应关系表的外键。

例如:对于“气体”学科,有问题的许可证应该有许可证的气体信息。如果tblGas中的PermitID是tblPermit的id的外键,那么它就有关系。如下所示:

代码语言:javascript
复制
+---------------+         +----------------------+
|               | 1     1 |                      |
|   tblPermit   |<------->| tblGas               |
|               |         | (for gas discipline) |
|               |         |                      |
+---------------+         +----------------------+
|               |         |                      |
| {PK} PermitId |         | {FK} PermitID        | <- ForeignKey to tblPermit.PermitID
|               |         |                      |
+---------------+         +----------------------+

您不需要Discipline列来选择正确的数据。您只需要一个查询就可以在许可证的标识符上查找tblElectrical、tblGas。这样,你就可以拿到你的许可证和它的信息了。

(PS。请原谅我使用UML类图来可视化数据库表,但是鱼尾纹符号在ASCII中不能很好地翻译)

票数 0
EN

Stack Overflow用户

发布于 2008-12-28 10:13:52

(如果tblPermit.Discipline是"G“,我们需要从tblGas中获取数据。如果tblPermit.Discipline是"E“,我们需要从tblElectrical中获取数据)。我到处乱搞,试图弄清楚这个问题,但到目前为止还没有任何运气。

鉴别器字段是无关紧要的,因为子类型的PK字段无论如何都是它们的父类型表的FK字段。所以这是一个表-子类型的映射。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/395431

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档