NHibernate QuerySyntaxException - PullRequest
       14

NHibernate QuerySyntaxException

11 голосов
/ 04 августа 2009

Я слежу за серией Summer of NHibernate Screencast и сталкиваюсь со странным исключением из NHibernate.

NHibernate.Hql.Ast.ANTLR.QuerySyntaxException:
Exception of type
'Antlr.Runtime.NoViableAltException' was thrown.
[select from DataTransfer.Person p where p.FirstName=:fn].

Я отклонился от серии Screencast следующими способами:

  1. Запуск с базой данных MS SQL Server Compact
  2. Я использую MSTest вместо MbUnit

Я пробовал любое количество комбинаций запросов всегда с одинаковым результатом. Мой нынешний синтаксис CreateQuery

public IList<Person> GetPersonsByFirstName(string firstName)
{
    ISession session = GetSession();

    return session.CreateQuery("select from Person p " +
        "where p.FirstName=:fn").SetString("fn", firstName)
        .List<Person>();
}

Хотя этот метод не является прямым запросом, он работает

public Person GetPersonById(int personId)
{
    ISession session = GetSession();
    return session.Get<Person>(personId);
}

My hibernate.cfg.xml

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
  <session-factory name="BookDb">
    <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
    <property name="connection.driver_class">NHibernate.Driver.SqlServerCeDriver</property>
    <property name="dialect">NHibernate.Dialect.MsSqlCeDialect</property>
    <property name="connection.connection_string">Data Source=C:\Code\BookCollection\DataAccessLayer\BookCollectionDb.sdf</property>
    <property name="show_sql">true</property>
    <property name="proxyfactory.factory_class">NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle</property>
    <mapping assembly="DataTransfer"/>
  </session-factory>
</hibernate-configuration>

Person.hbm.xml

<?xml version="1.0" encoding="utf-8" ?>
<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="DataTransfer" namespace="DataTransfer">
  <class name="DataTransfer.Person,DataTransfer" table="Person">
    <id name="PersonId" column="PersonId" type="Int32" unsaved-value="0">
      <generator class="native"/>
    </id>
    <property name="FirstName" column="FirstName" type="String" length="50" not-null="false" />
    <property name="LastName" column="LastName" type="String" length="50" not-null="false" />
  </class>
</hibernate-mapping>

Ответы [ 2 ]

18 голосов
/ 17 ноября 2009

Я также следил за серией Summer of NHibernate Screencast и столкнулся с той же проблемой.

Проблема в HQL " выберите из пользователя p ", измените его на " выберите p из пользователя p " или просто " из пользователя p " .

Сокращенная HQL-форма, которая использовалась в скринкастах под NHibernate версии 1.2, была устарела в 2.0 и исключена в 2.1.x, так как парсер запросов по умолчанию был переключен на будь более строгим вариантом.

public IList<Person> GetPersonsByFirstName(string firstName)
{
    ISession session = GetSession();

    return session.CreateQuery("select p from Person p where p.FirstName=:fn")
                              .SetString("fn", firstName)
                              .List<Person>();
}
5 голосов
/ 04 августа 2009

Поскольку вы указываете пространство имен в элементе <hibernate-mapping, вы можете написать:

 <class name="Person" table="Person">
  ....

После того, как вы попробуете это, если это не сработает - я понятия не имею, почему это не работает. Я попробовал пример, который вы привели, и он сработал.

Я видел, как новый синтаксический анализатор выдавал странные ошибки, и вам просто нужно идти методом проб и ошибок, когда это происходит: (.

Редактировать

О методе проб и ошибок: вы можете изменить запрос на "от лица", посмотрите, работает ли он (если он не ... я застрял). Затем добавьте фильтр, сначала попробуйте напрямую p.FirstName = 'x'. Тогда попробуйте с параметром. Вы можете попробовать не добавлять псевдоним.

Также попробуйте использовать последнюю версию NH.

Редактировать 2

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" assembly="NHibernateTests, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" namespace="NHibernateTests">

<class name="User" table="`User`" xmlns="urn:nhibernate-mapping-2.2">
<id name="Id" type="Int32" column="UserId">
  <generator class="assigned" />
</id>
<property name="UserName" type="String">
  <column name="UserName" not-null="true" />
</property>
<property name="FName" type="String">
  <column name="FName" />
</property>
  </class></hibernate-mapping>

и запрос:

IList<User> users = session.CreateQuery("select from User p " +
                              "where p.UserName=:fn").SetString("fn", "u")
                  .List<User>();

работал как шарм.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...