Symfony query - получить все элементы одного пользователя

Написал запрос на возврат всех карт, купленных конкретным пользователем. Я не знаю, что делаю не так. Я определил user_id в таблице карт и добавил несколько карт вручную тоже test.

Моя служба ..

public function getUserCardAction($userId)
{

    $card = $this->getCardRepository()
        ->createQueryBuilder('c')
        ->select('c')
        ->where('c.userId = :userId')
        ->setParameter('userId', $userId)
        ->getQuery()
        ->getResult();

    return $card;
}

Мой контроллер ..

public function getUserCard()
{

    $this->get('card.configuration')->getUserCardAction($this->getUser());

    return $this->success();

}

А какую ошибку вы получите?

WM-SH-PD-TV-FC 30.05.2018 14:50

Он возвращает ИСТИНА, но без данных. Я входил в карты с user_id 1 в db.

Филип Стојановић 30.05.2018 14:55

покажи нам свой класс сущности

Andrew Vakhniuk 30.05.2018 15:03

/ ** * @ORM \ Column (name = "user_id", type = "integer", nullable = true) * / private $ userId;

Филип Стојановић 30.05.2018 15:06
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
4
49
2

Ответы 2

Ты возвращаешься

$this->success();

Что это за функция?

Разве вы не должны возвращать результат вашего запроса? Нравиться :

return $this->get('card.configuration')->getUserCardAction($this->getUser());

Контроллер должен вернуть ответ (задан массив (0 => Object (Bundle \ Base \ Entity \ Card), 1 => Object (Bundle \ Base \ Entity \ Card))).

Филип Стојановић 30.05.2018 15:18

Да, в Symfony контроллер должен возвращать объект ответа. Вопрос в том, чего вы ожидаете в качестве отдачи. Вы вызываете его через ajax и хотите JsonResponse, или вы хотите передать данные, например, функции рендеринга. Вот почему я спросил, что внутри вашей функции успеха. Вы можете предоставить этот код?

WhiteRabbit 30.05.2018 15:43

Вы также можете получить результат напрямую через доктрину, чтобы сократить его $ this-> em-> getRepository ('App: Cart') -> findBy (['userId' => $ this-> getUser ()])

WhiteRabbit 30.05.2018 15:47

Я пытаюсь вернуть все карты, принадлежащие конкретному пользователю. (Пользователь с ID 1)

Филип Стојановић 30.05.2018 15:57

Мне удалось найти решение.

Я только что отредактировал свой Контроллер.

 $card = $this->get('card.configuration')->getUserCardAction($this->getUser());

    return $this->success($card);

Попробуйте добавить «-> getUserCardAction ($ this-> getUser () -> getId ())»

Dan Costinel 30.05.2018 16:18

Другие вопросы по теме