当我尝试使用 NHibernate 保存我的对象时,我收到一个错误“Invalid index ... for this SqlParameterCollection”。我已经阅读了很多关于这些问题的答案,但它们要么是关于 Fluent NHB 的,要么似乎不适用于我的问题(我可能错了)。
这是我的 hbm 和我的班级:
<class name="MyWebSite.Model.ADUser" table="AD_USER">
<id name="Id" column="ID">
<generator class="native"/>
</id>
<property name="Login" column="LOGIN"/>
<property name="Hidden" column="HIDDEN"/>
<many-to-one name="Resource" column="LOGIN" property-ref="Login" cascade="none" />
</class>
[DataContract()]
public class ADUser : Entity.AbstractPersistentObject
{
[DataMember(EmitDefaultValue = false)]
public virtual string Login { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual bool Hidden { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual AbstractHumanResource Resource { get; set; }
}
AbstractPersistentObject 不是我自己定义的类,我发现没有引用它的 hbm 文件,所以我猜它没有绑定到任何映射。它具有“ID”属性的定义(我什至没有使用其他属性)。
[DataContract()]
public abstract class AbstractPersistentObject
{
[DataMember(EmitDefaultValue = false)]
public virtual int? Id { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual DateTime DateCreated { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual DateTime? DateUpdated { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual DateTime? DateDeleted { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual string CreatedBy { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual string UpdatedBy { get; set; }
[DataMember(EmitDefaultValue = false)]
public virtual string DeletedBy { get; set; }
public override int GetHashCode()
{
return !Id.HasValue ? base.GetHashCode() : string.Concat(this.GetType().FullName, Id.Value).GetHashCode();
}
public override bool Equals(object obj)
{
return obj == null ? false : obj.GetHashCode() == this.GetHashCode();
}
public override string ToString()
{
return this.GetType() + "#" + this.Id;
}
}
(我没有看到这种继承的问题)
当我得到一个数据列表时,它工作正常。只有当我尝试保存它时它才会引发异常(我还没有尝试删除)。