Неверное выражение пути. Должно быть StateFieldPathExpression

0

Я получаю сообщение об ошибке [Semantical Error] line 0, col 57 near 'room FROM AppBundle:bookings': Error: Invalid PathExpression. Must be a StateFieldPathExpression. [Semantical Error] line 0, col 57 near 'room FROM AppBundle:bookings': Error: Invalid PathExpression. Must be a StateFieldPathExpression. У меня есть два объекта в AppBundle, которые являются Room и Bookings. как только я выполняю запрос, я получаю упоминаемую ранее ошибку. Здесь мой запрос:

$query = $em->createQuery(
                            'SELECT r ' .
                            'FROM AppBundle:Room r ' .
                            'WHERE r NOT IN ( ' .
                            'SELECT b.room ' .
                            'FROM AppBundle:Bookings b ' .
                            'WHERE NOT ( ' .
                            'b.check_out < :check_in ' .
                            'OR ' .
                            'b.check_in > :check_out ' .
                            ')' .
                            ') ' .
                            'ORDER BY r.id'
                    )
                    ->setParameter('check_in', $request->query->get('check-in'))
                    ->setParameter('check_out', $request->query->get('check-out'));
Теги:
doctrine2
query-builder

1 ответ

0

Я думаю, что проблема заключается в WHERE NOT. попробуйте с этим запросом:

$query = $em->createQuery(
                            'SELECT r ' .
                            'FROM AppBundle:Room r ' .
                            'WHERE r NOT IN ( ' .
                            'SELECT b.room ' .
                            'FROM AppBundle:Bookings b ' .
                            'WHERE  ' .
                            'b.check_out < :check_in ' .
                            'OR ' .
                            'b.check_in > :check_out ' .
                            ') ' .
                            'ORDER BY r.id'
                    )
                    ->setParameter('check_in', $request->query->get('check-in'))
                    ->setParameter('check_out', $request->query->get('check-out'));
  • 0
    спасибо за ваш ответ, но запрос работает нормально, когда я выполняю его в базе данных MySQL. проблема не в синтаксисе запроса.
  • 0
    не могли бы вы написать это с createQueryBuilder?

Ещё вопросы

Сообщество Overcoder
Наверх
Меню