교리 2를 사용하여 추가 데이터로 다대다 관계를 모델링하는 방법은 무엇입니까?
Oct 25, 2024 am 07:25 AM교리 2 및 추가 필드가 있는 다대다 링크 테이블
데이터베이스 모델링에서는 추가 데이터 포인트를 사용하여 다대다 관계를 표현하는 것이 어려울 수 있습니다. 널리 사용되는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

인기 기사

인기 기사

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











Laravel Back End : Part 2, React가있는 React 앱 구축

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법
