查找两个教义集合的相交

时间:2019-04-13 18:05:39

标签: php mysql collections doctrine

我正在使用Doctrine,并且具有以下SQL表:

  • 实体:id(pk)
  • x系列:id(pk),entity_id(fk引用entity.id),名称(字符串),位置(int)
  • y系列:id(pk),entity_id(fk引用entity.id),名称(字符串),位置(int)
  • x_y_intersect:x_series_id / y_series_id(将pk和fk组合为x / y_series),名称(字符串)

鉴于['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);

0 个答案:

没有答案