我有一个由symfony2中的crud生成的表。该实体被称为“Voorraad”(= Stock),是一个包含3个项目的表:“aantal”(= number),“locatie_id”(location_id)和“product_id”。位置ID和产品ID都与另一个enitty(locatie实体和产品实体)相关联。我尝试按位置订购我的库存,但我无法在symfony中找到它。我想选择一个位置(id 1,id 2,id 3),如果a选择了一个选项,它会输出该位置的数据。
在mysql中有以下查询
SELECT * FROM `voorraad` WHERE `locatie_id` = 1
如何在Symfony2 / doctrine / twig中实现这样的目标?
我的代码:
查看
{% extends '::base.html.twig' %}
{% block body -%}
<h1 class="hoofdtitel">Voorraad lijst</h1>
<table class="records_list">
<thead>
<tr>
<!-- <th>Id</th> -->
<th>Product</th>
<th>Type</th>
<th>Fabriek</th>
<th>Aantal</th>
<th>Inkoopprijs</th>
<th>Verkoopprijs
<th>Locatie</th>
<th>Actions</th>
</tr>
</thead>
<tbody>
{% for entity in entities %}
<tr>
<!-- <td><a href="{{ path('voorraad_show', { 'id': entity.id }) }}">{{ entity.id }}</a></td> -->
<td>{{ entity.getProduct().getNaam() }}</td>
<td>{{ entity.getProduct().getType() }}</td>
<td>{{ entity.getProduct().getFabric().getFabrieknaam() }}</td>
<td>{{ entity.aantal }}</td>
<td>{{ entity.getProduct().getInkoopprijs() }}</td>
<td>{{ entity.getProduct().getVerkoopprijs() }}</td>
<td>{{ entity.getLocatie().getLocatienaam() }}</td>
<td>
<a href="{{ path('voorraad_edit', { 'id': entity.id }) }}">Voorraad aanpassen</a>
</td>
</tr>
{% if
entity.aantal == 1 %}
<div class="alert alert-info" role="alert"> <p>Let op, voorraad van {{ entity.getProduct().getNaam() }} is 1 of minder </p></div>
{% endif %}
{% if
entity.aantal <= 0 %}
<div class="alert alert-danger" role="alert"> <p>Let op, voorraad van {{ entity.getProduct().getNaam() }} is op </p></div>
{% endif %}
{% endfor %}
</tbody>
</table>
<br>
<a href="{{ path('voorraad_new') }}">
Nieuwe voorraad toevoegen
</a>
{% endblock %}
控制器
namespace ToolsForEver\VoorraadBundle\Controller;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Method;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
use ToolsForEver\VoorraadBundle\Entity\Voorraad;
use ToolsForEver\VoorraadBundle\Form\VoorraadType;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Security;
/**
* Voorraad controller.
*
* @Route("/voorraad")
*/
class VoorraadController extends Controller
{
/**
* Lists all Voorraad entities.
*
* @Route("/", name="voorraad")
* @Method("GET")
* @Template()
* @Security("has_role('ROLE_USER')")
*/
public function indexAction()
{
$em = $this->getDoctrine()->getManager();
$entities = $em->getRepository('ToolsForEverVoorraadBundle:Voorraad')->findBy(array(), array('locatie'=>'asc'));
return array(
'entities' => $entities,
);
}
/**
* Creates a new Voorraad entity.
*
* @Route("/", name="voorraad_create")
* @Method("POST")
* @Template("ToolsForEverVoorraadBundle:Voorraad:new.html.twig")
*/
public function createAction(Request $request)
{
$entity = new Voorraad();
$form = $this->createCreateForm($entity);
$form->handleRequest($request);
if ($form->isValid()) {
$em = $this->getDoctrine()->getManager();
$em->persist($entity);
$em->flush();
return $this->redirect($this->generateUrl('voorraad_show', array('id' => $entity->getId())));
}
return array(
'entity' => $entity,
'form' => $form->createView(),
);
}
/**
* Creates a form to create a Voorraad entity.
*
* @param Voorraad $entity The entity
*
* @return \Symfony\Component\Form\Form The form
*/
private function createCreateForm(Voorraad $entity)
{
$form = $this->createForm(new VoorraadType(), $entity, array(
'action' => $this->generateUrl('voorraad_create'),
'method' => 'POST',
));
$form->add('submit', 'submit', array('label' => 'Create'));
return $form;
}
/**
* Displays a form to create a new Voorraad entity.
*
* @Route("/new", name="voorraad_new")
* @Method("GET")
* @Template()
* @Security("has_role('ROLE_USER')")
*/
public function newAction()
{
$entity = new Voorraad();
$form = $this->createCreateForm($entity);
return array(
'entity' => $entity,
'form' => $form->createView(),
);
}
/**
* Finds and displays a Voorraad entity.
*
* @Route("/{id}", name="voorraad_show")
* @Method("GET")
* @Template()
*/
public function showAction($id)
{
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository('ToolsForEverVoorraadBundle:Voorraad')->find($id);
if (!$entity) {
throw $this->createNotFoundException('Unable to find Voorraad entity.');
}
$deleteForm = $this->createDeleteForm($id);
return array(
'entity' => $entity,
'delete_form' => $deleteForm->createView(),
);
}
/**
* Displays a form to edit an existing Voorraad entity.
*
* @Route("/{id}/edit", name="voorraad_edit")
* @Method("GET")
* @Template()
* @Security("has_role('ROLE_USER')")
*/
public function editAction($id)
{
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository('ToolsForEverVoorraadBundle:Voorraad')->find($id);
if (!$entity) {
throw $this->createNotFoundException('Unable to find Voorraad entity.');
}
$editForm = $this->createEditForm($entity);
$deleteForm = $this->createDeleteForm($id);
return array(
'entity' => $entity,
'edit_form' => $editForm->createView(),
'delete_form' => $deleteForm->createView(),
);
}
/**
* Creates a form to edit a Voorraad entity.
*
* @param Voorraad $entity The entity
*
* @return \Symfony\Component\Form\Form The form
*/
private function createEditForm(Voorraad $entity)
{
$form = $this->createForm(new VoorraadType(), $entity, array(
'action' => $this->generateUrl('voorraad_update', array('id' => $entity->getId())),
'method' => 'PUT',
));
$form->add('submit', 'submit', array('label' => 'Update'));
return $form;
}
/**
* Edits an existing Voorraad entity.
*
* @Route("/{id}", name="voorraad_update")
* @Method("PUT")
* @Template("ToolsForEverVoorraadBundle:Voorraad:edit.html.twig")
*/
public function updateAction(Request $request, $id)
{
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository('ToolsForEverVoorraadBundle:Voorraad')->find($id);
if (!$entity) {
throw $this->createNotFoundException('Unable to find Voorraad entity.');
}
$deleteForm = $this->createDeleteForm($id);
$editForm = $this->createEditForm($entity);
$editForm->handleRequest($request);
if ($editForm->isValid()) {
$em->flush();
return $this->redirect($this->generateUrl('voorraad_edit', array('id' => $id)));
}
return array(
'entity' => $entity,
'edit_form' => $editForm->createView(),
'delete_form' => $deleteForm->createView(),
);
}
/**
* Deletes a Voorraad entity.
*
* @Route("/{id}", name="voorraad_delete")
* @Method("DELETE")
*/
public function deleteAction(Request $request, $id)
{
$form = $this->createDeleteForm($id);
$form->handleRequest($request);
if ($form->isValid()) {
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository('ToolsForEverVoorraadBundle:Voorraad')->find($id);
if (!$entity) {
throw $this->createNotFoundException('Unable to find Voorraad entity.');
}
$em->remove($entity);
$em->flush();
}
return $this->redirect($this->generateUrl('voorraad'));
}
/**
* Creates a form to delete a Voorraad entity by id.
*
* @param mixed $id The entity id
*
* @return \Symfony\Component\Form\Form The form
*/
private function createDeleteForm($id)
{
return $this->createFormBuilder()
->setAction($this->generateUrl('voorraad_delete', array('id' => $id)))
->setMethod('DELETE')
->add('submit', 'submit', array('label' => 'Verwijder voorraad'))
->getForm()
;
}
}
答案 0 :(得分:2)
您可以在控制器中为此目标创建一个方法。近似代码如下(但这完全取决于您的映射信息和属性名称)。
public function getVoorraadByLocatieId($locatieId)
{
$em = $this->getDoctrine()->getManager();
$query = $em->createQuery(
'SELECT v
FROM ToolsForEverVoorraadBundle:Voorraad v
WHERE v.locatie = :l_id'
)->setParameter('l_id', $locatieId);
$result = $query->getResult();
return $result;
}
在你的行动中,做:
$this->getVoorraadByLocatieId($locatieId);
有不同的方法可以实现相同的结果,比如创建服务并从控制器内部调用它(使用瘦控制器的胖服务是上帝的做法),或创建自定义存储库类,但想法是相同的(使用实体管理器和学说提取)。后一种方式的优点是代码组织/可读性。
答案 1 :(得分:2)
您可以使用doctrine的findBy方法:
$entities = $em->getRepository('ToolsForEverVoorraadBundle:Voorraad')
->findBy(['locatie'=>$locatieId]);