考虑下表映射,这不过是经典的用户安全角色映射示例。
<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
<class name="Model.User, Domain" table="[User]">
<id name="UserID" column="UserId" type="Int32">
<generator class="hilo">
<param name="table">NhibernateUniqueKey</param>
<param name="column">NextHi</param>
<param name="where">TableName='[User]'</param>
<param name="max_lo">20</param>
</generator>
</id>
<property name="UserName" column="UserName" type="String" length="20"/>
<property name="Password" column="Password" type="String" length="20"/>
.
.
<bag name="SecurityRoles" table="UserSecurityRole" lazy="false">
<key column="UserId"></key>
<many-to-many class="Model.SecurityRole, Domain" column="SecurityRoleId"></many-to-many>
</bag>
问题是当我通过用户名[使用条件查询]检索用户,并刷新会话时,所有附加到检索到的用户的安全角色都会被删除并重新插入,尽管我不对其进行任何修改后退的对象。
我在这里做错了什么,或者这是nhibernate的设计方式吗?
答案 0 :(得分:0)
这就是行李的行为。为避免这种情况,请使用idbag
或set
。