0

当创建类 B 的对象并尝试访问表单 $B-> C->attributeOfC 抛出 Doctrine_Record_UnknownPropertyException 'with message' 未知记录属性/相关组件

代码中的一个简单示例:

//A
class tableA extends Doctrine_Record{    
    public function setTableDefinition() {
        $this->hasColumn('tableA_id', 'integer', null, array(
            'primary' => true, 'autoincrement' => true));          
            $this->hasColumn('tableC_id','integer');
             $this->setSubclasses(array(
                'tableB'  => array('type' => 1)
            ));  }
    function setup() {
        $this->setTableName("tableA");
        $this->hasOne('tableC', array(
            'local' => 'tableC_id',
            'foreign' => 'tableC_id'
                ));    }
}
//B
class tableB extends tableA{
   public function setTableDefinition() {
        $this->hasColumn('tableB_id', 'integer', null, array(
            'primary' => true, 'autoincrement' => true));
            $this->hasColumn('tableA_id','integer');        
    }
    function setup() {
        $this->setTableName("tableB");
    }
}

//C
class tableC extends Doctrine_Record{   
    public function setTableDefinition() {
        $this->hasColumn('tableC_id', 'integer', null, array(
            'primary' => true, 'autoincrement' => true));
            $this->hasColumn('attributeOfC','string');
    }
    function setup() {
        $this->setTableName("tableC");
         $this->hasMany('tableA as Alias', array(
            'local' => 'tableC_id',
            'foreign' => 'tableC_id'
                )); }
}
 //some code where we create $objectOfCClass as an instance of tableCe
 $objectA = new $tableA(); 
 $objectA->tableC=$objectOfCClass;
 $objectA->save();
4

1 回答 1

1

在子类中定义函数时,例如TableB中的“setTableDefinition”,它不会调用父函数。您需要在 tableB setTableDefinition 函数中显式调用 parent::setTableDefinition(),以及在 tableB setup 函数中调用 parent::setup()。

//B
class tableB extends tableA{
   public function setTableDefinition() {
        parent::setTableDefinition();
        $this->hasColumn('tableB_id', 'integer', null, array(
            'primary' => true, 'autoincrement' => true));
            $this->hasColumn('tableA_id','integer');        
    }
    function setup() {
        parent::setup();
        $this->setTableName("tableB");
    }
}

现在,看起来 tableA 和 tableB 实际上是具有不同列的不同表,上面的代码会中断,因为它会告诉 tableB 它有一个名为 tableA_id 的列。因此,您必须根据哪些表具有哪些列来移动代码。您可以将他的“hasOne”调用复制到 tableB setTabledefinition 函数中。

要记住的是,这只是设置对象的 PHP 代码,这些类的继承与其他 PHP 类的工作方式相同。因此,将共同的东西带入父类,将不同的东西带入子类。

于 2011-06-04T17:30:43.923 回答