Nhibernate - 没有关系的连接表查询

时间:2009-03-10 02:06:23

标签: nhibernate join nhibernate-mapping

我想知道是否有人试图在NHibernate中这样做。

我有以下表格(simpify版本)。

CITY: 城市(varchar2)(PK) 省(varchar2)(PK)

CITY_TL: 城市(varchar2)(PK) 省(varchar2)(PK) lang(char(2))(PK)

LOCATION: location(varchar2)(PK) 其他一些专栏。

如您所见,CITY和LOCATION之间没有任何关系。 但是,它设置的方式是CITY.Province可以等于 LOCATION.Location。所以,我可以执行这样的查询:

选择c。* 来自城市c 在c.city = ctl.city上加入city_tl ctl 在l.location = c.province上加入位置l

我如何在NHibernate中做到这一点?这甚至可行吗?

这是我和CITY和LOCATION的映射文件

CITY:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                   assembly="NHDAL"
                   namespace="NHDAL.Domain">

  <class name="CityTL" table="CITY_TL">
    <composite-id>
      <key-property column="CITY" type="String" name="Name"/>
      <key-property column="PROVINCE" type="String" name="Province"/>
      <key-property column="LANG" type="String" name="Lang" />
    </composite-id>

    <timestamp
        column="MODIFY_DATE"
        name="ModifyDate"
        access="property"
        unsaved-value="null"/>

    <property name="ProvinceDescription" column="PROVINCE_TL"
type="String" not-null="true" />
    <property name="Description" column="CITY_TL" type="String" not-
null="true"/>
    <property name="SortOrder" column="SORT_ORDER" type="Int32" not-
null="false"/>

    <many-to-one name="City" class="City">
      <column name="CITY"/>
      <column name="PROVINCE"/>
    </many-to-one>
  </class>

</hibernate-mapping>

位置:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"
                   assembly="NHDAL"
                   namespace="NHDAL.Domain">

  <class name="Location" table="LOCATION">
    <id column="LOCATION" name="Name">
      <generator class="assigned" />
    </id>

    <timestamp
        column="MODIFY_DATE"
        name="ModifyDate"
        access="property"
        unsaved-value="null"/>

      </class>

</hibernate-mapping>

有人可以对此有所启发并告诉我该查询应该是什么 看起来像在NHibernate?

1 个答案:

答案 0 :(得分:0)

不相关的实体,您可以使用笛卡尔积将其与hql或SQL连接:

Here