1

次のコードを使用すると、サイレント エラーが発生することがあります。

public function updateCoreGameTableIfNecessary($coreEm)
{   
    $game = $this->getCoreGameRecord($coreEm);

    if (!$game) {

        $game = new Game();
        $game->setHomeSchool($this->getHomeSchool()->getCoreSchool($coreEm));
        $game->setDatetime($this->getDatetime()->format('Y-m-d H:i:s'));
        $game->setDate($this->getDatetime()->getTimestamp());
        $game->setTime($this->getDatetime()->format('H:i:s'));
        $game->setSport($coreEm->getRepository('VNNCoreBundle:Sport')->findOneByName($this->getSport()->getName()));
        $game->setSeason($coreEm->getRepository('VNNCoreBundle:Season')->findCurrent());
        $game->setEventType(strtolower($this->getEventType()->getName()));
        $game->setMeetName($this->getMeetName());
        $game->setRemoteUnique(md5(rand(0, 100000)));
        $game->setNotes($this->getRecap());
        $game->setHomeConfId(0); // This field is no longer used, so value doesn't matter.
        $game->setAwayConfId(0); // This field is no longer used, so value doesn't matter.
        $game->setConfStatus(''); // This field is going away as well.
    }   

    if ($this->getEventType()->getName() == 'Game') {
        $game->setHomeScore($this->getHomeScore());
        $game->setAwayScore($this->getAwayScore());
        $game->setAwaySchool($this->getAwaySchool()->getCoreSchool($coreEm));
    } else {
        $game->setPlace($this->getPlace());
        $game->setPoints($this->getHomeScore());
    }   

    $game->setOwnerId($this->getUser()->getSchool()->getCoreSchool($coreEm)->getId());
    $coreEm->persist($game);
    $coreEm->flush();

    return $game->getId();
}   

$thisそれは常にすでに保存されているから始まります。特定のインスタンス$this(つまり、データベース内の特定のレコード) について$gameは、保存されません。エラーなどは発生しません。黙って失敗するだけです。

デバッグに関する提案はありますか? これらの特定のレコードの違いを理解しようとするつもりですが、何らかの理由で挿入が黙って失敗することはないようです。

4

0 に答える 0