Я использую Doctrine и у меня есть следующие таблицы SQL:
- сущность: id (pk)
- x_series: id (pk), entity_id (fk ссылается на entity.id), имя (строка), позиция (int)
- y_series: 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;
EDIT. Похоже, что DQL нельзя использовать так, как я не упомянул, потому что я неправильно чувствовал себя неважным, сущности - это унаследованный класс, а все остальные унаследованные классы остаются объединенными.
В качестве альтернативного решения есть ли хороший ООП подход.
$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);