Doctrine 2で2つのテーブルを結合しようとすると、いくつかの問題が発生します。テーブルに新しいアイテムを追加しようとすると、次のエラーが発生します。
永続化操作をカスケードするように構成されていない関係を通じて、新しいエンティティが見つかりました:@。新しいエンティティを明示的に永続化するか、リレーションシップでカスケード永続化操作を構成します。
テーブルの行を更新しようとすると、次のエラーが発生します。
指定されたエンティティにはIDがありません。
ビューのイベントに関するデータを収集できるように、勝者エンティティのイベントIDをイベントのIDに結合しようとしています。更新用のフォームからIDが返されますが、更新できないようです。
更新: 少し遊んだ後、cascade = "{persist}"オプションを追加すると、クラスが見つかりませんというエラーが発生し、それを削除して完全な名前空間を追加すると、エンティティが存在しないと主張します...
<?php
namespace ZC\Entity;
/**
* ZC\Entity\Winner
*
* @Table(name="winner")
* @Entity(repositoryClass="ZC\Entity\Repository\Winner")
*/
class Winner
{
/**
* @var integer $id
*
* @Column(name="id", type="integer", nullable=false, unique=false, precision=0, scale=0)
* @Id
* @GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @var string $copy
*
* @Column(name="copy", type="text", length="", unique=false, nullable=true, precision=0, scale=0)
*/
protected $copy;
/**
* @var string $url
*
* @Column(name="url", type="string", length="255", unique=false, nullable=true, precision=0, scale=0)
*/
protected $url;
/**
*
* @ManyToOne(targetEntity="Events")
* @JoinColumns=({
* @JoinColumn(name="event", referencedColumnName="id")
* })
*
*/
protected $event;
/**
* __get function.
*
* @access protected
* @param mixed $property
* @return void
*/
public function __get($property) {
return $this->$property;
}
/**
* __set function.
*
* @access protected
* @param mixed $property
* @param mixed $value
* @return void
*/
public function __set($property, $value) {
$this->$property = $value;
}
}
<?php
namespace ZC\Entity;
/**
* ZC\Entity\Events
*
* @Table(name="events")
* @Entity(repositoryClass="ZC\Entity\Repository\Events")
*/
class Events
{
/**
* @var integer $id
*
* @Column(name="id", type="integer", nullable=false, unique=false, precision=0, scale=0)
* @Id
* @GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @var string $title
*
* @Column(name="title", type="string", length="255", unique=false, nullable=false, precision=0, scale=0)
*/
protected $title;
/**
* @var string $description
*
* @Column(name="description", type="text", length="", unique=false, nullable=true, precision=0, scale=0)
*/
protected $description;
/**
* @var string $status
*
* @Column(name="status", type="smallint", length="1", unique=false, nullable=false, precision=0, scale=0)
*/
protected $status = 0;
/**
* @var string $date
*
* @Column(name="date", type="string", length="255", unique=false, nullable=false, precision=0, scale=0)
*/
protected $date;
/**
* @var string $lang
*
* @Column(name="lang", type="string", length="255", unique=false, nullable=false, precision=0, scale=0)
*/
protected $lang;
/**
* __get function.
*
* @access protected
* @param mixed $property
* @return void
*/
public function __get($property) {
return $this->$property;
}
/**
* __set function.
*
* @access protected
* @param mixed $property
* @param mixed $value
* @return void
*/
public function __set($property, $value) {
$this->$property = $value;
}
}