쿼리 설명
원래 질문에서 사용자는 추가 필드(stock 양). Doctrine을 사용하여 재고 금액 값에 액세스하고 데이터베이스 테이블 구조를 생성할 때 문제가 발생했습니다.
문제 해결
이 문제는 다대다라는 가정에서 비롯되었습니다. - 추가 값이 있는 많은 관계는 그렇게 처리될 수 있습니다. 그러나 추가 값이 있는 다대다 관계는 식별자와 값을 가진 새로운 엔터티가 됩니다.
해결책
해결책에는 Stock이라는 별도의 엔터티를 만드는 것이 포함되었습니다. 다음 열 포함:
이를 통해 시스템은 Doctrine을 사용하여 재고 금액 값에 대한 액세스를 제공하여 다대다 관계를 정확하게 모델링할 수 있었습니다.
업데이트된 엔터티
아래는 조정된 엔터티입니다. 정의:
제품:
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; }
스토 re:
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; }
재고:
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; }
데이터베이스 구조
이 변경으로 인해 아래와 같은 데이터베이스 구조가 생겼습니다.
CREATE TABLE product ( id INT NOT NULL, product_name VARCHAR(50) NOT NULL, PRIMARY KEY (id) ); CREATE TABLE store ( id INT NOT NULL, store_name VARCHAR(50) NOT NULL, PRIMARY KEY (id) ); CREATE TABLE stock ( amount INT NOT NULL, store_id INT NOT NULL, product_id INT NOT NULL, PRIMARY KEY (store_id, product_id), FOREIGN KEY (store_id) REFERENCES store (id), FOREIGN KEY (product_id) REFERENCES product (id) );
위 내용은 교리 2의 추가 필드를 사용하여 다대다 관계를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!