2011-11-06 87 views
1

我有这样的问题:映射不起作用

假设我有一个用户,他是卡的性质:

public class User: Entity 
{ 
... 
public virtual IList<Card> Cards { get; set; } 
... 
} 

<class name="User" table="Users"> 
    <id name="Id" column="UserId"> 
     <generator class="guid"/> 
    </id> 
    <version name="Version"/> 
    ... 
    <list name="Cards" cascade="all" inverse="true"> 
     <key column="ViolatorId" not-null="true"/> 
     <index column="CardIndex"/> 
     <one-to-many class="Card"/> 
    </list> 
    ... 
</class> 

然后我从数据库中获取用户,将其添加到卡的列表中,并调用session.Update()。

生成此SQL代码:

INSERT INTO Cards 
      (Version, 
      ViolatorId, 
      ModeratorId, 
      IssueDate, 
      TermDate, 
      Cause, 
      Type, 
      CardId) 
VALUES  (1 /* @p0_0 */, 
      '6872df65-a1d7-40ef-abec-c14af96f3388' /* @p1_0 */, 
      '06060a30-252a-4f29-84fe-af5da110f049' /* @p2_0 */, 
      '2011-11-06T17:20:11.00' /* @p3_0 */, 
      '2011-11-06T22:20:11.00' /* @p4_0 */, 
      'Ad personam' /* @p5_0 */, 
      'Red' /* @p6_0 */, 
      '0454bbba-5ec9-429f-8830-d9cc33588f7a' /* @p7_0 */) 

的问题在于,所述请求不包含CardIndex的值,并填充它在数据库中作为NULL。

如何使NHibernate正常工作?

+0

当然,在这种情况下我可以使用Bag,但在项目中我有类似的例子。 –

回答

0

我已经使用Fluent NHibernate映射来定义实体映射。在你的情况下,用户和卡实体之间有一对多的关系。为了级联保存/更新/删除正常工作,您必须在两个实体之间定义适当的两个映射。另外,Cards实体应该对用户实体有参考。指使用功能NHibernate下面的链接对如何这种类型的映射被定义(在C#):

http://wiki.fluentnhibernate.org/Fluent_mapping#HasMany_.2F_one-to-many http://wiki.fluentnhibernate.org/Fluent_mapping#References_.2F_many-to-one

虽然代码是用C#给出的,但我认为它不应该很难理解发生了什么。

您还可以尝试以下方法来级联保存父子关系类型的实体。

public void Test() 
{ 
    using (IStatelessSession statelessSession = _sessionManager.OpenStatelessSession()) 
    { 
     using (ITransaction transaction = statelessSession.BeginTransaction()) 
     { 
      statelessSession.Insert(<ParentEntity>); 
      foreach(var childEntity in ParentEntity) 
      { 
       statelessSession.Insert(<childEntity>); 
      } 
      transaction.Commit(); 
     }  
    } 
} 

但是,为了正常工作,应该明确定义您的映射。

+0

流利很好,但现在完全在他的行动或混乱的项目,我不想。但无论如何感谢您的帮助。 –

+0

我使用流利的NHibernate,所以我用它作为分享我的知识的媒介。映射的想法实际上是相同的,并且在运行时(不知道它的运行时间或编译时间),生成的Sql将完全相同。 –

+0

我明白这一点,我只是想找到我做错了什么。也许我错过了一些属性? –