데이터베이스 모델링에서는 추가 데이터 포인트를 사용하여 다대다 관계를 표현하는 것이 어려울 수 있습니다. 널리 사용되는 PHP ORM인 Doctrine 2는 "링크 테이블"이라는 기술을 통합하여 솔루션을 제공합니다. 이러한 테이블은 엔터티 간의 중개자 역할을 하여 추가 정보를 캡처하는 동시에 연결을 촉진합니다.
다음 시나리오를 고려해 보세요. 매장과 제품 간의 다대다 관계가 있는 데이터베이스 모델을 생성하려고 합니다. 그러나 매장과 제품 간의 각 링크에는 사용 가능한 재고 수량과 같은 추가 값도 포함되어야 합니다.
처음에는 Many-to 사용을 고려했을 수도 있습니다. -링크 테이블에 직접 추가 필드가 있는 많은 관계. 그러나 교리 2는 이러한 연관이 실제로 다대다 관계가 아니라 자체 식별자를 가진 새로운 엔터티임을 인식합니다.
이 문제를 해결하려면 , 아래 데이터베이스 모델에서 볼 수 있듯이 주식 정보에 대해 별도의 엔터티를 생성하는 것이 좋습니다.
[별도의 Stock 엔터티가 있는 데이터베이스 모델 이미지]
제품:
<code class="php">namespace Entity; use Doctrine\ORM\Mapping as ORM; /** @ORM\Table(name="product") @ORM\Entity() */ class Product { /** @ORM\Id() @ORM\Column(type="integer") */ protected $id; /** ORM\Column(name="product_name", type="string", length=50, nullable=false) */ protected $name; /** @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="product") */ protected $stockProducts; }</code>
판매점:
<code class="php">namespace Entity; use Doctrine\ORM\Mapping as ORM; /** @ORM\Table(name="store") @ORM\Entity() */ class Store { /** @ORM\Id() @ORM\Column(type="integer") */ protected $id; /** ORM\Column(name="store_name", type="string", length=50, nullable=false) */ protected $name; /** @ORM\OneToMany(targetEntity="Entity\Stock", mappedBy="store") */ protected $stockProducts; }</code>
재고:
<code class="php">namespace Entity; use Doctrine\ORM\Mapping as ORM; /** @ORM\Table(name="stock") @ORM\Entity() */ class Stock { /** ORM\Column(type="integer") */ protected $amount; /** * @ORM\Id() * @ORM\ManyToOne(targetEntity="Entity\Store", inversedBy="stockProducts") * @ORM\JoinColumn(name="store_id", referencedColumnName="id", nullable=false) */ protected $store; /** * @ORM\Id() * @ORM\ManyToOne(targetEntity="Entity\Product", inversedBy="stockProducts") * @ORM\JoinColumn(name="product_id", referencedColumnName="id", nullable=false) */ protected $product; }</code>
이 접근 방식을 구현하면 이제 Stock 엔터티를 통해 주식 금액 값에 쉽게 액세스하고 교리 2에서 데이터 모델의 무결성을 유지할 수 있습니다.
위 내용은 교리 2를 사용하여 추가 데이터로 다대다 관계를 모델링하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!