繁体   English   中英

Nhibernate 3中的一对一映射

[英]one-to-one mapping in Nhibernate 3

我有以下课程

namespace Extractor.Mapping
{
    public class Application
    {
        public virtual Guid Id { get; set; }
        public virtual string intId { get; set; }
        virtual SQuery sQuery { get; set; }
    }
}


namespace Extractor.Mapping
{
    public class SQuery
    {
        public virtual int Id { get;set; } 
        public virtual Guid Application { get;set; } 
        public virtual string Type { get;set; }
    }
}

SQuery和Application之间的关系是SQuery中名为“ Application”的FK

这些是de hbm文件

Application.hbm.xml

<hibernate-mapping  xmlns="urn:nhibernate-mapping-2.2"
                    assembly="Extractor"
                    namespace="Extractor.Mapping">

  <class name="Application" >
    <id name="Id" column="Id">
      <generator class="assigned"/>
    </id>
    <property name = "intId" column = "IntId" type = "string"/>
    <one-to-one name="sQuery" property-ref ="Application" class="SicQuery"/>
  </class>
</hibernate-mapping>

<?xml version="1.0" encoding="utf-8" ?>

SQuery.hbm.xml

<hibernate-mapping  xmlns="urn:nhibernate-mapping-2.2"
                    assembly="BuroExtractorD"
                    namespace="BuroExtractorD.Mapping">
  <class name="SQuery" >
    <id name="Id" column="Id">
      <generator class="increment"/>
    </id>
    <property name="Application" column="Application" type ="Guid"/>
    <property name="Type" column="Type" type="string"/>
  </class>
</hibernate-mapping>

所以,事情是这样的,当我尝试访问一些SQuery对象的列表时,出现以下异常:

NHibernate.PropertyAccessException: Invalid Cast (check your mapping for property type mismatches); setter of Extractor.Mapping.SQuery ---> System.InvalidCastException

我试图像这样到达那里:

ICriteria crit = session.CreateCriteria(typeof(SQuery));
IList<SQuery> list = crit.List<SQuery>();

提前致谢

one-to-one关系就是参考关系。 这种映射不能与ValueTypes有关。

public class Application
{
    public virtual SQuery sQuery { get; set; }
    ...
}
public class SQuery
{
    // wrong, Guid is ValueType, not a reference 
    // public virtual Guid Application { get;set; } 
    // corrrect - one to one == bi-directional 
    public virtual Application Application { get;set; } 
    ...
}

映射应如下所示

<class name="Application" >
    ...
    // class should be SQuery
    //<one-to-one name="sQuery" property-ref ="Application" class="SicQuery"/>
    <one-to-one name="sQuery" property-ref="Application" class="SQuery"/>

 <class name="SQuery" >
    ...
    <many-to-one name="Application" class="Application" 
                 column="Application" unique="true"/>

在这里查看更多:

5.1.2。 休眠映射

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM