4

「ポリモーフィックアソシエーション」を使用するドクトリン2のコードの具体的なサンプルが必要です。はっきりさせておきます。コントラクトと呼ばれるエンティティがあり、コントラクトには多くの価格ルールを含めることができます。これらの価格ルールは、さまざまな種類のクラスであり、さまざまなテーブルに存在する可能性があります。これがポリモーフィックな関連付けとは何か、または私は間違っていると思いますか?

class contract {

    private $id;

    private $priceRules;


}

class discountRule implements priceRule{

    function calculate() {
         // calculate new price after this rule
    }
}

class extraSpecialRule implements priceRule {

    function calculate() {
        // calculate new price after this rule
    }
}

将来的には新しいタイプの価格ルールが存在する可能性がありますが、これらのルールをメインエンティティに関連付けて、別々のテーブルに表示するにはどうすればよいですか?

アップデート:

これは私の新しいコードです:

Contract.php

namespace Entities;

use Doctrine\Common\Collections\ArrayCollection;


/**
 * @Entity @Table(name="contract") 
 */ 
class Contract {

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

    /**
     * 
     * @Column(type="integer")
     */
    private $propertyId;

    /**
     * 
     * @Column(type="integer")
     */
    private $agencyId;

    /**
     * 
     * @OneToMany(targetEntity="priceRule" ,mappedBy="contract")
     * 
     */
    private $priceRules;

    public function __construct($propertyId,$agencyId){
        $this->propertyId=$propertyId;
        $this->agencyId=$agencyId;
        $this->priceRules=new ArrayCollection();
    }

    public function addPriceRule(priceRule $rule){
        $this->priceRules[]=$rule;  
    }

    public function getPriceRules(){
        return $this->priceRules;
    }
}

pricerule.php

namespace Entities;

/**
 * @Entity
 * @InheritanceType("JOINED")
 * @DiscriminatorColumn(name="discr" , type="string")
 * @DiscriminatorMap({"discountrule"="discountRule","extradiscountrule"="extraDiscountRule"})
 */
class priceRule{
    /**
     * 
     * @Id @Column(type="integer")
     * @GeneratedValue(strategy="AUTO")
     */
    private $id;

     /**
      * 
      * @ManyToOne(targetEntity="contract",inversedBy="availibilityRules")
      * @JoinColumn("contract_id",referencedColumnName="id")
      */
    private $contract;

}

discountrule.php

namespace Entities;

/**
 * @Entity
 * 
 *
 */
class discountRule extends priceRule {

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

    public function calculatePrice(){
         // calculate new price
    }

}

extradiscountrule.php

namespace Entities;

/**
 * @Entity
 * 
 *
 */
class extraDiscountRule extends priceRule {

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


        public function calculate() {
            // calculate new price
        }

}

sampleusage.php

$contract=new Contract(1,1);
$discount=new discountRule();

$em->persist($discount);

$contract->addPriceRule($discount);

$em->persist($contract->getPriceRules());
$em->persist($contract);

$em->flush();

しかし、コントラクトに新しいルールを追加しようとすると、エラーメッセージが表示されます(致命的なエラー:キャッチされない例外'Doctrine \ ORM \ Mapping \MappingException'とメッセージ'ClassDoctrine \ Common \ Collections\ArrayCollectionは有効なエンティティまたはマップされたスーパークラスではありません。)

私は何を間違っているのですか?

4

2 に答える 2

5

PriceRule親オブジェクトに@MappedSuperclassがない可能性があります

参照:継承マッピング

于 2010-12-22T09:39:51.110 に答える
0

インターフェイスはクラスのプロパティを定義できないため、これは不可能です。そのため、Doctrineが操作するプロパティがあることを保証することはできません。

あなたがあなたの実体についてより多くの詳細を提供することができれば、私はより良く助けることができます。

于 2010-11-23T04:36:13.747 に答える