错误使用流畅的Nhibernate与位使属性值脱水

时间:2013-04-10 17:15:58

标签: c# nhibernate fluent-nhibernate fluent-nhibernate-mapping

我有这堂课:

public class Person
{
   public virtual long     ID            { get; set; }
   public virtual string   FirstName     { get; set; }
   public virtual string   LastName      { get; set; }
   public virtual boolean  IsValid       { get; set; }
}

和人员数据映射:

public class PersonMap : ClassMap<Person>
    {
        public PersonMap()
        {
            Id(x => x.ID);
            Map(x => x.FirstName).Not.Nullable().Length(100);
            Map(x => x.LastName).Not.Nullable().Length(100);
            Map(x => x.IsValid).Not.Nullable();
        }
    }

这是表格架构:

CREATE TABLE [dbo].[Person](
    [ID] [bigint] IDENTITY(1,1) NOT NULL,
    [FirstName] [nvarchar](100) NOT NULL,
    [LastName] [nvarchar](100) NOT NULL,    
    [IsValid ] [bit] NOT NULL,
PRIMARY KEY CLUSTERED 
(
    [ID] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

当我使用Fluent NHibernate在数据库中插入新的Person时,我们遇到了这个问题:

error dehydrating property value for `NameSpaceA.IsValid`

内在异常:

_innerException = {"Invalid index 2 for this SqlParameterCollection with Count=2."}

2 个答案:

答案 0 :(得分:2)

正如Jamie Ide所说,尝试显式映射由身份生成的Id,但也检查并查看从IsValid映射中删除.Not.Nullable()是否允许它工作。因为在c#中,类型是布尔值,所以无论如何它都不能为空。

public PersonMap()
{
    Id(x => x.ID).GeneratedBy.Identity();
    Map(x => x.FirstName).Not.Nullable().Length(100);
    Map(x => x.LastName).Not.Nullable().Length(100);
    Map(x => x.IsValid);
}

答案 1 :(得分:0)

请提供完整的错误消息和堆栈跟踪。这是一条错误消息,通常会误导,因为在此之前发生了其他错误。

我猜测根本原因是你没有为ID属性声明一个生成器。它被打字的事实也可能是一个问题。你是如何生成/设置ID属性的?

假设您使用的是标识列(int),映射将为:

Id(x => x.ID).GeneratedBy.Identity();