Heim > Backend-Entwicklung > PHP-Tutorial > 刚开始学symfony2框架,哪位师兄能指教一下一对多映射怎么做么?有命令生成不?

刚开始学symfony2框架,哪位师兄能指教一下一对多映射怎么做么?有命令生成不?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-06 20:50:13
Original
974 Leute haben es durchsucht

class Mapp
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var string $name
     *
     * @ORM\Column(name="name", type="string", length=255, nullable=false)
     */
    private $name;

    /**
     * @var string $saysay
     *
     * @ORM\Column(name="saysay", type="string", length=255, nullable=false)
     */
    private $saysay;

    /**
     * @var string $log
     *
     * @ORM\Column(name="log", type="text", nullable=false)
     */
    private $log;


}
class People
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var string $name
     *
     * @ORM\Column(name="name", type="string", length=255, nullable=false)
     */
    private $name;

    /**
     * @var string $discuss
     *
     * @ORM\Column(name="discuss", type="string", length=255, nullable=false)
     */
    private $discuss;


}
Nach dem Login kopieren
Nach dem Login kopieren

回复内容:

class Mapp
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var string $name
     *
     * @ORM\Column(name="name", type="string", length=255, nullable=false)
     */
    private $name;

    /**
     * @var string $saysay
     *
     * @ORM\Column(name="saysay", type="string", length=255, nullable=false)
     */
    private $saysay;

    /**
     * @var string $log
     *
     * @ORM\Column(name="log", type="text", nullable=false)
     */
    private $log;


}
class People
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var string $name
     *
     * @ORM\Column(name="name", type="string", length=255, nullable=false)
     */
    private $name;

    /**
     * @var string $discuss
     *
     * @ORM\Column(name="discuss", type="string", length=255, nullable=false)
     */
    private $discuss;


}
Nach dem Login kopieren
Nach dem Login kopieren

友情提示:Doctrine 2的Mapping信息(映射信息)可以用XML,YAML,PHP和注解这四种格式来编写。

A和B的一对一关系,在数据库里,可以在A上弄个字段存相应B记录的ID,也可以反过来在B上存A的ID,也可以互相存ID,这个是Doctrine 2里所说的关联方向。

你问题例子里的是注解方式的,那我就说注解的:

(1)单向,在A表上产生一个字段来存B的ID。

/** @Entity **/
class A
{
    // ...

    /**
     * @OneToOne(targetEntity="B")
     * @JoinColumn(name="b_id", referencedColumnName="id")
     **/
    private $b;

    public function getB()
    {
        return $this->b;
    }
}

/** @Entity **/
class B
{
    // ...
}
Nach dem Login kopieren

在拿到A的情况下,可以用$a->getB()来获得与$a关联的B。

joinColumn那一句,大多数情况是可以省略的,Doctrine 2会自动生成关联字段的名称。

(1)双向

/** @Entity **/
class A
{
    // ...

    /**
     * @OneToOne(targetEntity="B", mappedBy="a")
     **/
    private $b;

    public function getB()
    {
        return $this->b;
    }
}

/** @Entity **/
class B
{
    // ...

    /**
     * @OneToOne(targetEntity="A", inversedBy="b")
     **/
    private $a;

    public function getA()
    {
        return $this->a;
    }
}
Nach dem Login kopieren

$a->getB()和$b->getA(),都可以直接取关联对象。

targetEntity(关联哪个对象/表)里多了一个mappedBy和inversedBy,他们的值,其实就是被关联对象上用来保存关联ID的属性的名字。

标记了mappedBy的,将成为关联关系的“拥有者”。

Verwandte Etiketten:
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Aktuelle Ausgaben
PHP-Datenerfassung?
Aus 1970-01-01 08:00:00
0
0
0
PHP-Erweiterung intl
Aus 1970-01-01 08:00:00
0
0
0
Wie man PHP gut lernt
Aus 1970-01-01 08:00:00
0
0
0
Mehrere PHP-Versionen
Aus 1970-01-01 08:00:00
0
0
0
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage