nhibernate map sql хранимая процедура для сущности - PullRequest
0 голосов
/ 08 июня 2011

Отредактировано: я нашел другое решение для вызова хранимой процедуры через NHibernate и сопоставления ее с моей сущностью:

 var campaignsItems = nhSession.CreateSQLQuery("exec Select_List_Campaigns :currentLatDegrees, :currentLonDegrees, :radiusInMiles, :pageSize, :currentPage, :search, :isTop, :topDealPercente")
                 .SetParameter("currentLatDegrees", currentLatDegrees)
                 .SetParameter("currentLonDegrees", currentLonDegrees)
                 .SetParameter("radiusInMiles", radius)
                 .SetParameter("pageSize", pageSize)
                 .SetParameter("currentPage", page)
                 .SetParameter("search", search)
                 .SetParameter("isTop", isTop)
                 .SetParameter("topDealPercente", topDealPercente)
                 .SetResultTransformer(Transformers.AliasToBean<CampaignListModel>())
                 .List<CampaignListModel>();

Как вы можете видеть, здесь мы можем установить параметры и отобразить результаты для нашей сущности с помощью SetResultTransformer.,Если свойства в вашем классе совпадают с именами столбцов в наборе результатов вашей хранимой процедуры, то все будет в порядке.

Старый вопрос:

У меня есть некоторая хранимая процедура, и я хочу сопоставить свою сущность снабор записей результатов этой хранимой процедуры.Мой файл hbm:

<?xml version="1.0" encoding="utf-8" ?>
  <hibernate-mapping xmlns="urn:nhibernate-mapping-2.2">
    <sql-query name="Select_Latest_Campaigns">
        <return alias="cfl" class="Austradelia.Core.ProcedureResultEntities.CampaignForList, Austradelia.Core">
          <return-property name="Id" column="Id"></return-property>
          <return-property name="ShortDescription" column="ShortDescription"></return-property>
          <return-property name="CampaignType" column="CampaignType"></return-property>
          <return-property name="StartDate" column="StartDate"></return-property>
          <return-property name="FinishDate" column="FinishDate"></return-property>
          <return-property name="Quantity" column="Quantity"></return-property>
          <return-property name="TotalRedeemsCount" column="TotalRedeemsCount"></return-property>
          <return-property name="MerchantId" column="MerchantId"></return-property>
          <return-property name="MerchantBusinessName" column="MerchantBusinessName"></return-property>
          <return-property name="MerchantAddress" column="MerchantAddress"></return-property>
          <return-property name="MerchantFollowersCount" column="MerchantFollowersCount"></return-property>
          <return-property name="TipsCount" column="TipsCount"></return-property>
          <return-property name="LikesCount" column="LikesCount"></return-property>
          <return-property name="CategoryId" column="CategoryId"></return-property>
          <return-property name="CategoryName" column="CategoryName"></return-property>
          <return-property name="RowNumber" column="RowNumber"></return-property>
          <return-property name="TotalCount" column="TotalCount"></return-property>
        </return>
        exec Select_Latest_Campaigns :currentLatDegrees, :currentLonDegrees, :radiusInMiles, :pageSize, :currentPage, :search
    </sql-query>
  </hibernate-mapping>

Когда я пытаюсь выполнить этот запрос, у меня возникает следующее исключение:

Exception Details: NHibernate.HibernateException: Errors in named queries: {Select_Latest_Campaigns}

Вкл .:

Line 43:             return configuration.BuildSessionFactory();

Любые идеи, что не так

1 Ответ

0 голосов
/ 08 июня 2011

измените persistence.xml, добавив это свойство:

<property name="hibernate.query.factory_class" value="org.hibernate.hql.classic.ClassicQueryTranslatorFactory" />

Я надеюсь, что эта помощь, если не, дайте мне знать, какая у вас версия sql!?

...