So I have an Experiment Entity which has many RNASeq entities. However, when I try to save an Experiment with an RNASeq entry (via the newAction
), only the Experiment portion saves.
My controller is as follows:
<?php
// src/AppBundle/Controller/ExperimentController.php
namespace AppBundle\Controller;
use AppBundle\Entity\Experiment;
use AppBundle\Entity\RNASeq;
use AppBundle\Form\Type\ExperimentType;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Symfony\Component\HttpFoundation\Response;
// TODO: deleteAction should be implemented.
class ExperimentController extends Controller {
/**
* @Route("/experiment/index", name="experiment_index")
*/
public function indexAction() {
// Grab all experiments from database and hand them to template.
$repository = $this->getDoctrine()->getRepository('AppBundle:Experiment');
$experiments = $repository->findAll();
return $this->render('experiment/index.html.twig',['experiments' => $experiments]);
}
/**
* @Route("/experiment/new", name="experiment_new")
*/
public function newAction(Request $request) {
$experiment = new Experiment();
$form = $this->createForm(ExperimentType::class, $experiment);
$form->handleRequest($request);
// On submission.
if ($form->isValid()) {
$em = $this->getDoctrine()->getManager();
$em->persist($experiment);
// For each nested object.
foreach($experiment->getRNASeqs() as $rnaseq) {
$em->persist($rnaseq);
}
$em->flush();
return $this->redirectToRoute('experiment_index');
}
return $this->render('experiment/form.html.twig', array('form' => $form->createView()));
}
/**
* @Route("/experiment/show/{id}", name="experiment_show")
* TODO: Not sure if nessesary (wasn't in last system).
*/
public function showAction($id) {
return $this->render('experiment/show.html.twig');
}
/**
* @Route("/experiment/edit/{id}", name="experiment_edit")
*/
public function editAction(Request $request, $id) {
$repository = $this->getDoctrine()->getRepository('AppBundle:Experiment');
$experiment = $repository->find($id);
$form = $this->createForm(ExperimentType::class, $experiment);
$form->handleRequest($request);
return $this->render('experiment/form.html.twig', array('form' => $form->createView()));
}
}
?>
I've attempted to follow the Symfony documentation. However, it doesn't specifically go over a One-to-Many example, and I fear this is possibly where I've messed up.
For the sake of brevity my Entity classes and the rest of my code can be found here.
Edit:
I've noticed that during a creation event, the insert into
events don't seem to have the correct relationship attributes:
INSERT INTO experiment (title, exp_type, sample_nums) VALUES (?, ?, ?)
Parameters: { 1: fe, 2: RNASeq, 3: 'a:1:{i:0;i:68767;}' }
INSERT INTO rnaseq (quality, ribodepleted, final_quality, sample_num, protocol_used, step1, step1result, service_provider, platform, data_files, pipeline, pipeline_parameters, result_files, experiment_id) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
Parameters: { 1: fds, 2: 0, 3: fes, 4: 7876, 5: esf, 6: 0, 7: fsd, 8: fs, 9: fs, 10: fsd, 11: sdf, 12: fds, 13: fsd, 14: null }
Experiment
appears to be missing an update to its rnaSeqs
attribute, and RNASeq
has a null
parameter for experiment_id
.