对于 Accommodation 实体,我们有两列可为空:CollectionType
and AccommodationUnitType
.
但是我注意到数据中它们被设置为零而不是 null,导致 NHibernate 尝试查找 id 为 0 的实体。这是很多额外不必要的数据库调用,因此我将数据库中的相关数据更新为 NULL,突然我得到了一个很大的错误:
“索引 24 对此无效
计数 = 24 的 SqlParameterCollection"
这是我正在使用的映射覆盖:
public void Override(AutoMapping<Core.Entities.Itinerary.Accommodation.Accommodation> mapping)
{
...
mapping.References(x => x.CollectionType).Nullable();//.Not.LazyLoad();
mapping.References(x => x.AccommodationUnitType).Nullable();//.Not.LazyLoad();
Cache.Is(c => c.ReadWrite());
}
谷歌有很多答案似乎与我的问题无关。
有任何想法吗?
Edit
“CollectionType”和“AccommodationUnitType”是否都指定为“int”?
当使用空值时,您需要将它们都指定为“int?”。
不确定这是否是您遇到的问题,但它为我纠正了类似的问题。
public virtual int? CollectionType {get;set;}
public virtual int? AccommodationUnitType {get;set;}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)