我正在使用Doctrine,并且具有以下SQL表:
鉴于['entityId'=>123, 'xPosition'=>3, 'yPosition'=>5]
,我想找回相交的物体。
一种选择是使用SQL(或DQL)(可以进行优化,但为清晰起见,请按照以下说明编写):
SELECT xyi.*
FROM entities e
INNER JOIN x_series xs ON xs.entity_id=e.id
INNER JOIN y_series ys ON ys.entity_id=e.id
INNER JOIN x_y_intersect xyi ON xyi.x_series_id=xs.id AND xyi.y_series_id=ys.id
WHERE e.id=:entityId AND xs.position=:xPosition AND ys.position=:yPosition;
编辑。似乎无法使用DQL,因为我错误地认为它不重要,实体是一个继承的类,而所有其他继承的类则保持连接状态。
作为一种替代解决方案,有没有一种好的OOP方法。
$entity=$this->read($id);
$xSeries=$entity->getXseries();
$ySeries=$entity->getYseries();
$xNode=$xSeries->offsetGet($xPosition);
$yNode=$ySeries->offsetGet($yPosition);
//How should this be accomplished?
$intersect=$this->getXYnodeIntersect($entity, $xNode, $yNode);