使用流畅的 nhibernate 表继承删除对象时出现异常。
我无法弄清楚我的应用程序结构和映射有什么问题,以及为什么在我使用表继承时它正在寻找多对多映射表?
添加和更新工作正常。
我没有明确设置任何映射,我使用的是默认的流畅 nhibernate 映射。
对于处理我的级联的覆盖,如下所示:
public class CascadeAll : IHasOneConvention, IHasManyConvention, IReferenceConvention
{
public void Apply(IOneToOneInstance instance)
{
instance.Cascade.All();
}
public void Apply(IOneToManyCollectionInstance instance)
{
instance.Cascade.All();
}
public void Apply(IManyToOneInstance instance)
{
instance.Cascade.All();
}
}
例外是:
Invalid object name 'BlogPageToPage'.
Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.
Exception Details: System.Data.SqlClient.SqlException: Invalid object name 'BlogPageToPage'.
我的数据库看起来像这样。
Page
Id (Guid)
Name
etc.
BlogPage
Page_Id (Guid, exact same as parent page)
etc.
课程:
public class Page : EntityBase
{
public Page()
{
BlogPages = new List<BlogPage>();
}
public virtual IList<BlogPage> BlogPages { get; set; }
}
public class BlogPage : Page
{
public BlogPage()
{
}
public virtual IList<Post> Posts { get; set; }
}
我的删除看起来像这样:
public bool Delete(T model)
{
Session.Delete(model);
return true;
}
感谢您的输入。