我有一个相当复杂的实体,当特定的数据库表缺少记录时,它不会保存。当记录存在时,实体会正确保存。当记录没有我收到异常时:
此 SqlParameterCollection 的索引 N 无效,Count=N
在阅读了通过 Google 找到的一堆解决方案以及 Stack Overflow 上最密切相关的问题之后:
- 当数据库中的列为 Null 时,是什么导致“Count=nn 的此 SqlParameterCollection 的索引 nn 无效”?
- 此 SqlParameterCollection 的索引 n 无效,Count=n”或“外键不能为空
我相信我的问题与我设置映射文件的方式有关。Customer 实体引用了 Person 实体。Person 映射到我们已经读取但没有写入权限的表。当 Person 实体的记录不存在时,我会生成异常。如果记录存在没有问题。我已将 Person 从 customer 的引用设置为Nullable()
. 我还仔细检查了以确保我没有从任一实体映射两次的属性。
以下是我觉得相关的映射信息,但可以根据需要提供更多:
顾客
//more mapping code...
References(x => x.Person, "snl_id").Nullable();
//more mapping code...
人
//more mapping code...
ReadOnly();
Id(x => x.SnlId).Column("SNL_ID");
//more mapping code...
更复杂的是,我们有一些痛苦的代码来让 NHibernate 在 Person 不存在时表现得更好。我不确定它是否适用于此,但认为它足够相关,可以包含在我的问题中。我们使用下面的代码,因为没有它,NHibernate JIRA 将创建大量查询。此Stack Overflow 答案中概述了此解决方案。
客户的个人财产
public virtual Person Person
{
get
{
try
{
var snlId = per.Name;
return per;
}
catch
{
return null;
}
}
set
{
per = value;
}
}
private EPerson per;
我的映射中缺少什么会导致此异常?我没有看到这个问题的另一个部分吗?