0

使用流畅的 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;
    }

感谢您的输入。

4

2 回答 2

0

我当然是个白痴。

它正在寻找该表的原因是因为我将 BlogPages 作为父级 Page 对象上的列表。

因此,当我尝试删除它时,它只是认为那里应该有另一个表来匹配该关联。

违规线路:

    public virtual IList<BlogPage> BlogPages { get; set; }
于 2012-06-13T05:09:17.173 回答
0

“BlogPageToPage”与您的任何数据库或表或列名都不匹配...您能找到您提到“BlogPageToPage”对象的位置吗?

于 2012-06-13T04:08:36.880 回答