Doctrine orm 许多人不使用继承

Doctrine orm 许多人不使用继承,doctrine-orm,symfony4,Doctrine Orm,Symfony4,我正在开发一款应用程序,它可以与捐赠者和拥有捐赠者的公司打交道。两者都继承一个名为“Organization”的超类 我想在它们之间添加一个单向的多人关系,但当我要求doctrine实现数据库,并用固定装置将其水合时,我无法检索公司拥有的给予者 Doctrine甚至没有创建一个giver_company表,它可以像它应该做的那样包含关系信息 这是我的密码: 组织机构 <?php // src/Entity/Chain/Organization.php namespace App\Entit

我正在开发一款应用程序,它可以与捐赠者和拥有捐赠者的公司打交道。两者都继承一个名为“Organization”的超类

我想在它们之间添加一个单向的多人关系,但当我要求doctrine实现数据库,并用固定装置将其水合时,我无法检索公司拥有的给予者

Doctrine甚至没有创建一个giver_company表,它可以像它应该做的那样包含关系信息

这是我的密码:

组织机构

<?php
// src/Entity/Chain/Organization.php
namespace App\Entity\Chain;

use App\Entity\User;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;

/**
 * @ORM\Entity
 * @ORM\InheritanceType("SINGLE_TABLE")
 * @ORM\DiscriminatorColumn(name="type", type="string")
 * @ORM\DiscriminatorMap({"association" = "Association", "super_association" = "SuperAssociation", "company" = "Company", "giver" = "Giver"})
 */

abstract class Organization
{

    /**
     * @ORM\Id
     * @ORM\GeneratedValue
     * @ORM\Column(type="integer")
     */
    private $id;

    /**
     * @ORM\Column(type="string", length=255)
     * @Assert\NotBlank()
     */
    private $name;

    /**
     * @ORM\Column(type="string", length=255, nullable=true)
     */
    private $address;

    /**
     * @ORM\Column(type="string", length=255, nullable=true)
     */
    private $city;

    /**
     * @ORM\Column(type="string", length=255, nullable=true)
     */
    private $zipcode;

    /**
     * @ORM\Column(type="string", length=255, nullable=true)
     */
    private $SIREN;

    /**
     * @ORM\Column(type="string", length=255, nullable=true)
     */
    private $phone;

    /**
     * @ORM\OneToOne(targetEntity="App\Entity\Photo")
     */
    private $photo;

    /**
     * @ORM\OneToMany(targetEntity="App\Entity\User", mappedBy="memberOf")
     */
    private $members ;

    /**
     * Organization constructor.
     */
    public function __construct()
    {
        $this->members = new ArrayCollection();
    }


    public function getId()
    {
        return $this->id;
    }

    public function getName()
    {
        return $this->name;
    }

    /**
     * @param mixed $name
     */
    public function setName($name): void
    {
        $this->name = $name;
    }

    public function getAddress()
    {
        return $this->address;
    }

    /**
     * @param mixed $address
     */
    public function setAddress($address): void
    {
        $this->address = $address;
    }

    public function getCity()
    {
        return $this->city;
    }

    /**
     * @param mixed $city
     */
    public function setCity($city): void
    {
        $this->city = $city;
    }

    public function getZipcode()
    {
        return $this->zipcode;
    }

    /**
     * @param mixed $zipcode
     */
    public function setZipcode($zipcode): void
    {
        $this->zipcode = $zipcode;
    }

    public function getSIREN()
    {
        return $this->SIREN;
    }

    /**
     * @param mixed $SIREN
     */
    public function setSIREN($SIREN): void
    {
        $this->SIREN = $SIREN;
    }

    public function getPhone()
    {
        return $this->phone;
    }

    /**
     * @param mixed $phone
     */
    public function setPhone($phone): void
    {
        $this->phone = $phone;
    }

    public function getPhoto()
    {
        return $this->photo;
    }

    /**
     * @param mixed $photo
     */
    public function setPhoto($photo): void
    {
        $this->photo = $photo;
    }

    public function getMembers()
    {
        return $this->members;
    }

    public function addMember(User $member)
    {
        if (!$this->members->contains($member)) {
            $this->members->add($member);
        }
    }

    public function removeMember(User $member){
        $this->members->remove($member);
    }
}

您的文档块用于公司中的给予者在开头缺少一个“*”

更改:

/*
* @ORM\ManyToMany(targetEntity="App\Entity\Chain\Giver")
*/
private $givers ;


真是个傻瓜,我以为这是继承问题,但不是。谢谢,很抱歉浪费时间
<?php
    // src/Entity/Chain/Company.php
    namespace App\Entity\Chain;

    use Doctrine\Common\Collections\ArrayCollection;
    use Doctrine\ORM\Mapping as ORM;

    /**
     * @ORM\Entity()
     */
    class Company extends Organization
    {
        /**
         * @ORM\Id
         * @ORM\GeneratedValue
         * @ORM\Column(type="integer")
         */
        private $id;

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

        /*
         * @ORM\ManyToMany(targetEntity="App\Entity\Chain\Giver")
         */
        private $givers ;

        /**
         * Company constructor.
         */
        public function __construct()
        {
            parent::__construct();
            $this->givers = new ArrayCollection();
        }


        /**
         * @return mixed
         */
        public function getId()
        {
            return $this->id;
        }

        /**
         * @return mixed
         */
        public function getType()
        {
            return $this->type;
        }

        /**
         * @param mixed $type
         */
        public function setType($type): void
        {
            $this->type = $type;
        }



        public function getGivers()
        {
            return $this->givers;
        }

        public function addGiver(Giver $opening)
        {
            if (!$this->givers->contains($opening)) {
                $this->givers->add($opening);
            }
        }

        public function removeGiver(Giver $opening){
            $this->givers->remove($opening);
        }
    }
/*
* @ORM\ManyToMany(targetEntity="App\Entity\Chain\Giver")
*/
private $givers ;
/**
* @ORM\ManyToMany(targetEntity="App\Entity\Chain\Giver")
*/
private $givers ;