Как запросить отношения многих ко многим в NHibernate? - PullRequest
1 голос
/ 06 сентября 2011

Я очень новичок в NHibernate, и я хотел бы начать разработку с использованием этой замечательной технологии.

Ниже приведен список отношений между таблицами:

Схемы таблиц

tableschemas http://dl.dropbox.com/u/33698629/Entities.JPG

tblAirport
  AirportID
  AirportShortName
  AirportFullName
  AirportTel

tblGroup
  GroupID
  GroupName

tblAirportGroup
  AirportID
  GroupID

Я определил схемы hbm.xml, как показано ниже:

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
  <class name="TelDir.Core.Domain.Airport, TelDir.Core" table="tblAirport" lazy="false">
    <id name="ID" column="AirportID" unsaved-value="0">
      <generator class="identity" />
    </id>

    <property name="AirportShortName" column="AirportShortName" />
    <property name="AirportFullName" column="AirportFullName" />

    <set name="Groups" cascade="none" table="tblAirportGroup" lazy="false" access="readonly">
      <key column="AirportId"/>
      <many-to-many class="TelDir.Core.Domain.Group, TelDir.Core" column="GroupId"/>
    </set>


  </class>
</hibernate-mapping>


<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
  <class name="TelDir.Core.Domain.Group, TelDir.Core" table="tblGroup" lazy="false">
    <id name="ID" column="GroupID" unsaved-value="0">
      <generator class="identity" />
    </id>

    <property name="GroupName" column="GroupName" />   

    <bag name="Airports" cascade="none" table="tblAirportGroup" lazy="false" >
      <key column="GroupID"/>
      <many-to-many class="TelDir.Core.Domain.Airport, TelDir.Core" column="AirportId"/>
    </bag>
  </class>
</hibernate-mapping>

Правильно ли мое сопоставление?Как я могу получить список групп (GroupName), принадлежащих аэропорту?

Я пытался использовать этот синтаксис

ISession session = NHibernateSessionManager.Instance.GetSession();
ISet<Group> rValue = session.CreateCriteria(typeof(Airport))
.CreateCriteria("Groups")
.Add(Expression.Eq("ID", ap.ID))
.List() as ISet<Group>;

, но он не дал мне результата.

Не могли бы вы рассказать мне об этом?

С уважением,

1 Ответ

0 голосов
/ 07 сентября 2011

Так вы можете получить группы, которые содержат Аэропорт с идентификатором 33, например:

var groups = session.CreateCriteria<Group>()
                 .CreateCriteria("Airports")
                 .Add(Restrictions.Eq("ID", 33))
                 .List<Group>();
...