[英]Nhibernate , collections and compositeid
我有下表:
Bucket(
bucketId smallint (PK)
name varchar(50)
)
BucketUser(
UserId varchar(10) (PK)
bucketId smallint (PK)
)
复合键不是可以解决的问题,但是我希望我的存储桶类包含一个BucketUser的IList。 我阅读了在线参考资料,并认为自己已经破解了,但是还没有。 这两个映射如下
-斗-
<class name="Bucket,Impact.Dice.Core" table="Bucket">
<id name="BucketId" column="BucketId" type="Int16" unsaved-value="0">
<generator class="native"/>
</id>
<property column="BucketName" type="String" name="BucketName"/>
<bag name="Users" table="BucketUser" inverse="true" generic="true" lazy="true">
<key>
<column name="BucketId" sql-type="smallint"/>
<column name="UserId" sql-type="varchar"/>
</key>
<one-to-many class="Bucket,Impact.Dice.Core" not-found="ignore"/>
</bag>
</class>
-bucketUser-
<class name="BucketUser,Impact.Dice.Core" table="BucketUser">
<composite-id>
<key-many-to-one name="BucketUser" class="Bucket,Impact.Dice.Core" column="BucketId"/>
<key-property name="UserId" column="UserId" type="string"></key-property>
</composite-id>
</class>
密钥是包含实体的外键,而不是主键。
您有两种选择:
Bucketuser是一个独立的实体 。 它具有自己的映射定义,您可以使用一对多引用。 在您的情况下,您会得到一个复合键,但是我会避免这种情况。
<!-- reference to BucketUser. There is not table attribute needed. -->
<bag name="Users" inverse="true" generic="true" lazy="true">
<key>
<!-- foreign key -->
<column name="BucketId" sql-type="smallint" />
</key>
<one-to-many class="Bucket,Impact.Dice.Core" not-found="ignore"/>
</bag>
<!-- BucketUser mapped as an independent entity -->
<class name="BucketUser" ... >
<!-- here is the composite id, try to avoid this -->
<composite-id>
<key-property name="BucketId">
<key-property name="UserId">
</composite-id>
</bag>
Bucketuser是Bucket的从属部分。 桶的外键同时是主键:
<!-- The table is defined on the fly by the table attribute -->
<bag name="Users" table="BucketUser" inverse="true" generic="true" lazy="true">
<key>
<column name="BucketId" sql-type="smallint" />
</key>
<!-- use composite-element to define the contents of the table -->
<composite-element>
<!-- define the contents of the BucketUser here -->
<property name="UserId" sql-type="varchar"/>
</composite-element>
</bag>
这取决于您的情况,哪种策略合适。
你遇到了什么错误? 如果您确实剪切并粘贴了该映射,那么解决方案可能就像替换逗号一样简单。
<one-to-many class="Bucket,Impact.Dice.Core" not-found="ignore"/>
有一段时间。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.