NHibernate QuerySyntaxException
Я следую вместе с Summer of NHibernate Screencast Series и нахожусь в странном исключении NHibernate.
NHibernate.Hql.Ast.ANTLR.QuerySyntaxException:
Exception of type
'Antlr.Runtime.NoViableAltException' was thrown.
[select from DataTransfer.Person p where p.FirstName=:fn].
Я отклонился от серии Screencast следующими способами:
- Работа с компактной базой данных MS SQL Server
- Я использую 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);
}
Мой 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>
Ответы
Ответ 1
Я также следил за Summer of the NHibernate Screencast Series и столкнулся с одной и той же проблемой.
Проблема заключается в том, что в HQL " выберите из пользователя p" измените значение " выберите p из пользователя p" или просто " от пользователя p".
Сокращенная форма HQL, которая использовалась в screencasts под версией 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>();
}
Ответ 2
Поскольку вы указываете пространство имен в элементе <hibernate-mapping
, вы можете написать:
<class name="Person" table="Person">
....
После того, как вы попробуете это, если это не сработает - я понятия не имею, почему он не работает. Я пробовал в значительной степени пример, который вы дали, и это сработало.
Я видел, как новый парсер бросает некоторые странные ошибки, и вам просто нужно пройти пробную версию и ошибку, когда это произойдет: (.
Edit
О проб и ошибке: вы можете изменить запрос на "от лица", посмотрите, работает ли это (если он не... я застрял). Затем добавьте фильтр, сначала попробуйте прямо 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>();
Работал как шарм.