我有这堂课:
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."}
答案 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();