gpt4 book ai didi

c# - 相关表中的流利 nhibernate 鉴别器

转载 作者:行者123 更新时间:2023-11-30 18:01:07 25 4
gpt4 key购买 nike

我有以下 3 个表的示例值

Vehicles ( id = 1, type_id = 20 , ... )
Vehicle_Types ( vt_id = 20, class_id = 160, ... )
Vehicle_Classes ( vcls_id = 160, name = "Concrete1" )

我有

public class Concrete1 : Vehicle
{

}

我希望 nhibernate 在加载车辆 #1 时实例化一个 Concrete1在

Vehicle /*Concrete1*/ v = session.load<Vehicle>(1);

我如何使用自动映射来做到这一点?提前致谢。

编辑1

我开始认为这是不可能的,因此我们将不胜感激任何解决方法。 xml(非流利)版本的任何线索也可能有很大帮助。

最佳答案

好吧,首先是坏消息。

  • 您不能在单独的表中使用鉴别器,句号。您可以通过使用以连接作为源的 select 语句来解决这个问题 table ,但是您的实体实际上是只读的。或者您可以使用一个 View ,它可以工作,但将更多工作委托(delegate)给数据库。
  • 即使映射正确,session.load<Vehicle>(1)永远不会返回派生类型(除非您禁用延迟加载,这是一个坏主意,或者如果具体实例已经在 session 中加载)。您可以使用 this hack 获取具体实例.

现在,您的数据模型看起来更适合 Vehicle has-a Type关系比<ConcreteVehicle> is-a Vehicle一个。

这为您提供了更大的灵 active (例如,您可以更改车辆的类型),并且您可以通过使用策略模式(车辆类型包含行为)来保留多态性特征。

关于c# - 相关表中的流利 nhibernate 鉴别器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9450032/

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