gpt4 book ai didi

c# - 子类的映射列表

转载 作者:行者123 更新时间:2023-11-30 17:17:11 24 4
gpt4 key购买 nike

我有一个关于列表的 NHibernate 问题,列表被映射为抽象类的子类。

首先是抽象类的映射:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
auto-import="false"
assembly="Magma.Core"
namespace="Magma.Core.Business">
<class name="SyndicatePart" table="biz_syndicatepart" abstract="true" lazy="false">
<id name="Id" column="id">
<generator class="guid.comb" />
</id>
<discriminator column="parttype" not-null="true" />

<property name="Identifier" column="name" not-null="true" />
<property name="Share" column="share" not-null="true" />
<property name="CadasterNumber" column="cadaster_number" not-null="true" />

<many-to-one name="Account" column="accountid" lazy="proxy" cascade="all" />
<many-to-one name="Syndicate" column="syndicateid" lazy="proxy" cascade="all" />

<subclass name="Condo" discriminator-value="condo" lazy="false">
<property name="OwnerType" column="ownertype" />

<many-to-one name="Building" column="buildingid" />
<many-to-one name="Address" column="addressid" />

<bag name="Tenants" access="field.camelcase-underscore" table="biz_tenant" inverse="true" cascade="all-delete-orphan">
<key column="syndicatepartid" />
<one-to-many class="Tenant" />
</bag>
</subclass>

<subclass name="Parking" discriminator-value="park" lazy="false" />
<subclass name="Locker" discriminator-value="lock" lazy="false" />
</class>
</hibernate-mapping>

注意子类“Condo”、“Parking”和“Locker”(在我的例子中,只有 Condo 有额外的属性)。这是使用这些子类列表的对象映射:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
assembly="Magma.Core"
namespace="Magma.Core.Business">
<class name="Syndicate" table="biz_syndicate" abstract="true" lazy="false">
<id name="Id" column="id">
<generator class="guid.comb" />
</id>
<discriminator column="orientation" not-null="true" />

<property name="Name" column="name" not-null="true" />

<many-to-one name="Manager" column="managerid" cascade="all-delete-orphan" />

<bag name="Buildings" table="biz_building" inverse="true" cascade="all-delete-orphan">
<key column="syndicateid" />
<one-to-many class="Building" />
</bag>

<bag name="Parkings" table="biz_syndicatepart" inverse="true" cascade="all-delete-orphan">
<key column="syndicateid" />
<one-to-many class="Parking" />
</bag>

<bag name="Lockers" table="biz_syndicatepart" inverse="true" cascade="all-delete-orphan">
<key column="syndicateid" />
<one-to-many class="Locker" />
</bag>

<subclass name="VerticalSyndicate" discriminator-value="vertical" lazy="false" />
<subclass name="HorizontalSyndicate" discriminator-value="horizontal" lazy="false" />
</class>
</hibernate-mapping>

每个列表都映射为一个包,指向同一个表,但根据列表(Condo、Parking 和 Locker)属于不同的类。

现在来解决问题。问题是,当我尝试访问这些列表中的任何一个时,NHibernate 获取 biz_syndicatepart 表中的 所有 行,并根据列表将其转换为正确的类。假设我在表中有 3 行,如果我访问 Parkings 列表,我将有 3 个 parking 位。如果我访问 Lockers 列表,我将拥有 3 个储物柜!这是为 parking 列表生成的 SQL:

SELECT parkings0_.syndicateid     as syndicat7_1_,
parkings0_.id as id1_,
parkings0_.id as id39_0_,
parkings0_.name as name39_0_,
parkings0_.share as share39_0_,
parkings0_.cadaster_number as cadaster5_39_0_,
parkings0_.accountid as accountid39_0_,
parkings0_.syndicateid as syndicat7_39_0_
FROM biz_syndicatepart parkings0_
WHERE parkings0_.syndicateid = '2310fcdf-8ab3-48dd-9a75-9f1e00f6f4fd' /* @p0 */

首先,请注意双 parkings0_.id。这是正常的吗? parkings0_.syndicateid(选择语句的第一行和最后一行)也是如此。这个我真的不明白。

此外,请注意插入no discriminating WHERE 子句以指定我想要的列表类型。我假设如果我访问 Parkings 列表,我会看到一个 WHERE [discriminator-column] = [discriminator-value],在我的例子中是 WHERE parttype = 'park' 但它不在语句中,所以这就是返回每一行的原因。

我读到这可能是 NHibernate 中的一个错误(我目前使用的是 3.1 GA 版)但是阅读错误的描述似乎是在使用表时列表的键位于子类表中​​时发生的per subclass strategy (joined-subclass) 所以我认为它不适用于我的情况。

有人可以帮我解决这个问题吗?!我的映射文件有问题吗?为什么在 SELECT 中使用双 _id 而没有鉴别符 WHERE 子句?

最佳答案

简单的解决方法是向您的集合映射添加一个 where 子句。例如。

    <bag name="Parkings" table="biz_syndicatepart" inverse="true" cascade="all-delete-orphan" where="parttype='park'">
<key column="syndicateid" />
<one-to-many class="Parking" />
</bag>

关于c# - 子类的映射列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6748947/

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