CollectionType добавляет действие для очистки базы данных - PullRequest
0 голосов
/ 11 декабря 2018

Я создал CollectionType форму, которая может добавлять неограниченное количество TicketTime сущностей в одну Ticket сущность.Он связан через базу данных отношением OneToMany.

Что я пытаюсь сделать, это добавить один Ticket и несколько TicketTime s в базу данных одновременно.Например, один Ticket и 3 TicketTime с.

Я хотел бы знать, как создать этот метод, чтобы я мог взять один Ticket & несколько TicketTime с и сбросить их вбаза данных.

Действие My Controller:

    public function createTicket(Request $request)
    {
        if ($this->get('security.authorization_checker')->isGranted('IS_AUTHENTICATED_FULLY')) {
            if ($this->getUser()->getrole() == 3) {
                $em = $this->getDoctrine()->getManager();
                $ticket = new Ticket();
                $timeArray = new ArrayCollection();

                $form = $this->createForm(TicketType::class, $ticket);

                $form->handleRequest($request);

                if ($form->isSubmitted() && $form->isValid()) {
                    foreach ($timeArray as $time) {
                        $time->setTicket($ticket);
                        $em->persist($time);
                    }
                    $ticket->setTaken(0);

                    $em->persist($ticket);
                    $em->flush();

                    return $this->redirectToRoute('main');
                }
                return $this->render(
                    'create_ticket.html.twig',
                    array('form' => $form->createView())
                );
            }
        }
        return $this->redirectToRoute('main');
    }

Объект заявки:

/**
 * @Assert\NotBlank()
 * @ORM\OneToMany(targetEntity="TicketTime", mappedBy="ticket", fetch="EXTRA_LAZY", orphanRemoval=true, cascade={"persist"})
 */
private $ticketTimes;
public function setTicketTimes($time): void
{
    $this->ticketTimes = $time;
}
/**
 * @return ArrayCollection|TicketTime[]
 */
public function getTicketTimes()
{
    return $this->ticketTimes;
}

Объект TicketTime:

/**
 * @ORM\ManyToOne(targetEntity="Ticket", inversedBy="time")
 * @ORM\JoinColumn(nullable=false)
 */
private $ticket;

public function getTicket()
{
    return $this->ticket;
}

public function setTicket($ticket): void
{
    $this->ticket = $ticket;
}

1 Ответ

0 голосов
/ 12 декабря 2018

Мне удалось это исправить самостоятельно:)

Что было не так: мне нужно было создать метод add в сущности Ticket, поэтому я смогу добавить столько TicketTime, сколько захочу, вот код, которыйЯ добавил в сущность Ticket:

public function addTicketTime(TicketTime $time)
{
    $this->ticketTimes[] = $time;
    $time->setTicket($this);
    return $this;
}

Я также добавил несколько строк в контроллер

........
if ($form->isSubmitted() && $form->isValid()) {
    $ticketTimes = $form->get('ticketTimes')->getData();

    foreach ($ticketTimes as $time) {
        $ticket->addTicketTime($time);
    }
.......
...