목차
回复内容:
백엔드 개발 PHP 튜토리얼 刚开始学symfony2框架,哪位师兄能指教一下一对多映射怎么做么?有命令生成不?

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

Jun 06, 2016 pm 08:50 PM
php symfony

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的,将成为关联关系的“拥有者”。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

CakePHP 날짜 및 시간

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

CakePHP 프로젝트 구성

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

CakePHP 파일 업로드

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

CakePHP 라우팅

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP 토론

CakePHP 빠른 가이드 CakePHP 빠른 가이드 Sep 10, 2024 pm 05:27 PM

CakePHP 빠른 가이드

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법 Dec 20, 2024 am 11:31 AM

PHP 개발을 위해 Visual Studio Code(VS Code)를 설정하는 방법

See all articles