Я определил сущность "TrainingProgressEntry" как @ORM \ Entity и свойство "training", например:
/**
* @ORM\ManyToOne(targetEntity="Training", inversedBy="training_progress")
* @ORM\JoinColumn(name="training_id", referencedColumnName="id")
*/
protected $training;
Соответствующий @ORM \ Entity "Training" определяет свойство "training_progress", подобное
/**
* @ORM\OneToMany(targetEntity="TrainingProgressEntry", mappedBy="training", cascade={"remove"})
* @ORM\OrderBy({"entry_date" = "ASC"})
*/
protected $training_progress;
и метод получения для него вот так
/**
* Get trainingProgress
*
* @return \Doctrine\Common\Collections\ArrayCollection
*/
public function getTrainingProgress()
{
return $this->training_progress;
}
Наконец, я определяю метод получения, предназначенный для возврата только тех записей, у которых дата более поздняя, чем некоторая контрольная дата:
/**
* @return \Doctrine\Common\Collections\ArrayCollection
*/
public function getTrainingProgressSinceStart()
{
$startTime = $this->getUser()->getStart();
$criteria = Criteria::create()
->andWhere(Criteria::expr()->gt('entry_date', $startTime))
->orderBy(['entry_date', 'ASC']);
return $this->getTrainingProgress()->matching($criteria);
}
При использовании этой последней функции я получаю следующее «ContextErrorException»:
Notice: Undefined property: AppBundle\Entity\TrainingProgressEntry::$1
из
vendor\doctrine\collections\lib\Doctrine\Common\Collections\Expr\ClosureExpressionVisitor.php
при попытке «вернуть $ object -> $ field».
Трассировка показывает, что она вызвана вышеупомянутой функцией "getTrainingProgressSinceStart ()" в строке
return $this->getTrainingProgress()->matching($criteria);
По какой-то причине функция сопоставления не распознается или что-то ...
Я действительно не знаю, что искать сейчас.
Любые советы приветствуются.