2

我有一个模型 Anketauser_id作为主键,而不仅仅是id. 我想为它创建一个 HAS_ONE 关系,所以我编写了这个代码:

function relations()
{
return array(
...
'last_experience' => array(
    self::HAS_ONE, 'Experience', 'user_id',
    'condition' => '
        `signoff` = (
        SELECT MAX( `signoff` )
        FROM `experience` AS t2
        WHERE t2.user_id = last_experience.user_id )
    ',
),  
);
}

但是当我尝试获取此属性时,我得到“未定义属性“Anketa.id”。” 错误。

我在 CActiveFinder.php 文件中发现了一些执行以下操作的代码:

if($this->relation instanceof CBelongsToRelation)
{
    if(is_int($i))
    {
        if(isset($parent->_table->foreignKeys[$fk]))  // FK defined
            $pk=$parent->_table->foreignKeys[$fk][1];
        else if(is_array($this->_table->primaryKey)) // composite PK
            $pk=$this->_table->primaryKey[$i];
        else
            $pk=$this->_table->primaryKey;
    }
    $params[$pk]=$record->$fk;
}

此块id由于某种原因返回而不是user_id. 我不知道这是否是一个错误,因为其他关系工作正常,但它们没有这个复杂。

为什么会这样?我怎样才能解决这个问题?

谢谢!

4

1 回答 1

7

尝试将 PK 字段留空并使用“开”条件覆盖。

function relations()
{
    return array(
        'last_experience' => array(
            self::HAS_ONE,
            'Experience',
            '',
            'on' => 'user_id=last_experience.user_id'
        ),
    );
}
于 2013-01-08T13:15:03.580 回答