2

我有这堂课:

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."}
4

2 回答 2

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);
}
于 2013-04-11T16:09:25.797 回答
0

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

我会冒险猜测根本原因是您没有为 ID 属性声明生成器。它的类型很长这一事实也可能是一个问题。您如何生成/设置 ID 属性?

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

Id(x => x.ID).GeneratedBy.Identity();
于 2013-04-10T21:11:34.603 回答