欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2022-05-13 17:25:19
...
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;


}

回复内容:

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;


}

友情提示: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
{
    // ...
}

在拿到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;
    }
}

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

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

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