在从表中删除记录时,我遇到了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无法映射到仓库,因为记录已被删除。
请帮助或建议我需要做些什么来防止这种情况发生。
非常感谢!
答案 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。