Symfony2删除记录实体问题

时间:2013-11-10 22:31:40

标签: php mysql sql entity-framework symfony

在从表中删除记录时,我遇到了Symfony2的问题。

我有一个存储以下内容的表:purchaseOrders,purchaseOrderItems和仓库

采购订单实体“purchaseOrders”

 id|name   |
 -----------
 1 |Test   |

仓库实体“仓库”

 id|name             |
 ---------------------
 1 |Test Warehouse   |
 2 |Test Warehouse 2 |

采购订单表项目实体“purchaseOrderItems”

 id|name        |purchaseOrder_id|warehouse_id
 --------------------------------
 1 |Test Item 1 |1               |1
 2 |Test Item 2 |1               |1
 3 |Test Item 3 |1               |2

purchaseOrder_id是链接到名为“purchaseOrders”的表的多对一关系。 warehouse_id是一个多对一关系,链接到一个名为“仓库”的表。

我的view.html.twig页面有点像:

 PurchaseOrder
 --------------------------------------
 | | Item         | Warehouse
 --------------------------------------
 |1| Test Item 1  | Test Warehouse
 |2| Test Item 2  | Test Warehouse
 |3| Test Item 3  | Test Warehouse 2

如果我从“仓库”表中删除记录#1,我在此view.html.twig模板中收到错误

  An exception has been thrown during the rendering of a template ("Entity was not found.") in /Applications/XAMPP/xamppfiles/htdocs/symfonydev/src/WIC/PurchaseOrderBundle/Resources/views/PurchaseOrder/view.html.twig at line 320.

问题是因为当树枝模板试图访问仓库“名称”时,它无法在对象中找到它来呈现它...

我已经尝试了以下条件语句,没有任何作用,我仍然得到同样的错误:

 {% if purchaseOrderItems.warehouses.name != null %}
      {{ purchaseOrderItems.warehouses.name }}
 {% endif %}

 {% if purchaseOrderItems.warehouses.name is defined %}
      {{ purchaseOrderItems.warehouses.name }}
 {% endif %}

 {% if purchaseOrderItems.warehouses.name is not null %}
      {{ purchaseOrderItems.warehouses.name }}
 {% endif %}

我需要知道的是:

当我删除“仓库”时,我该怎么做才能使“purchaseOrderItems”与“仓库”的关系不会破坏或在值中加入Null或0。

问题必须是purchaseOrderItems无法映射到仓库,因为记录已被删除。

请帮助或建议我需要做些什么来防止这种情况发生。

非常感谢!

2 个答案:

答案 0 :(得分:0)

第一个错误,twig错误,你应该这样写

{% if purchaseOrderItems.warehouses %}
  {{ purchaseOrderItems.warehouses.name }}
{% endif %}

然后你的问题:

我找不到教条可以自动完成的方式。

因此,在删除一个仓库时,只需将purchaseOrder中的仓库设置为null即可。毕竟,这是一个坏主意,你会搞砸数据。

答案 1 :(得分:0)

尝试使用leftJoin创建一个QueryBuilder,而不是接近Twig中的warehouses.name:

$q = $repository->createQueryBuilder('p', 'w')->leftJoin('p.warehouse', 'w');
$columns = array('p.id', 'p.name', 'w.name as warehouse');
$products = $q->select($columns)->getQuery()->getResult();

然后你应该按照预期得到NULL。