NHibernate.PropertyValueException:not null属性引用null或瞬态
我得到以下例外情况 NHibernate.PropertyValueException:not null属性引用null或瞬态 这是我的映射文件 产品NHibernate.PropertyValueException:not null属性引用null或瞬态,nhibernate,nhibernate-mapping,Nhibernate,Nhibernate Mapping,我得到以下例外情况 NHibernate.PropertyValueException:not null属性引用null或瞬态 这是我的映射文件 产品 <class name="Product" table="Products"> <id name="Id" type="Int32" column="Id" unsaved-value="0"> <generator class="identity"/> </id>
<class name="Product" table="Products">
<id name="Id" type="Int32" column="Id" unsaved-value="0">
<generator class="identity"/>
</id>
<set name="PriceBreaks" table="PriceBreaks" generic="true" cascade="all" inverse="true" >
<key column="ProductId" />
<one-to-many class="EStore.Domain.Model.PriceBreak, EStore.Domain" />
</set>
</class>
跟进一月的答复。我已从priceBreak地图中删除ProductId。这个有用
public int AddPriceBreak(Product product, PriceBreak priceBreak)
{
using (ISession session = EStore.Domain.Helpers.NHibernateHelper.OpenSession())
using (ITransaction transaction = session.BeginTransaction())
{
product.AddPriceBreak(priceBreak);
session.SaveOrUpdate(product);
transaction.Commit();
}
return priceBreak.Id;
}
您对Id属性和实际引用的使用不正确 首先,删除此行:
<property name="ProductId" column="ProductId" type="Int32" not-null="true" />
(您可能需要将
Load
方法添加到存储库中)。从映射和PriceBreak类中删除ProductId属性。使用PriceBreaks集合来添加PriceBreaks,您不需要PriceBreakRepository,只需要ProductRepository
例如:
using (var session = sessionFactory.OpenSession())
{
using (var tx = session.BeginTransaction())
{
var product = session.Get<Product>(19);
product.AddPriceBreak(new PriceBreak());
tx.Commit();
}
}
谢谢jan,尝试过这个,但它没有传递产品id。请参见上文
<property name="ProductId" column="ProductId" type="Int32" not-null="true" />
priceBreak.Product = session.Load<Product>(19);
using (var session = sessionFactory.OpenSession())
{
using (var tx = session.BeginTransaction())
{
var product = session.Get<Product>(19);
product.AddPriceBreak(new PriceBreak());
tx.Commit();
}
}
class Product
{
// ...
public void AddPriceBreak(PriceBreak pb)
{
pb.Product = this;
PriceBreaks.Add(pb);
}
}