0

我必须验证表中是否存在具有双主键的记录。

$ssd=Ssd::model()->find(array(
                                'condition' => "id_scaglione=:sca AND COD_FIS LIKE :cf",
                                'params' => array(
                                                ':sca' => $sca_attivo->attributes['ID_SCAGLIONE'],
                                                ':cf' => $codfisc
                                            )
                            ));

但我有一个“为 foreach() 提供的参数无效”错误。

我认为是模型中声明关系的问题......

我在搜索主键时遇到同样的错误

$ssd = Scaglioni::model()->findByPk($sca_attivo->attributes['ID_SCAGLIONE'], $codfisc);

使用 Ssd 模型的覆盖方法:

public function primaryKey(){
    return array('ID_SCAGLIONE', 'COD_FIS');
}

这里是模型的关系:

斯卡廖尼

class Scaglioni extends CActiveRecord{
public function relations()
    {
        return array(
            'ssd' => array(self::HAS_MANY, 'Ssd', 'ID_SCAGLIONE'),
        );
    }
}

学生

class Studenti extends CActiveRecord{
public function relations()
    {
        return array(
            'ssd' => array(self::HAS_MANY, 'Ssd', 'COD_FIS'),
            'scaglioni' => array(self::HAS_MANY, 'Scaglioni', array('ID_SCAGLIONE'=>'ID_SCAGLIONE'), 'through'=>'ssd'),

        );
    }
    }

固态硬盘

class Ssd extends CActiveRecord{
public function relations()
    {
        return array(               
            'scaglioni' => array(self::BELONGS_TO, 'Scaglioni', 'ID_SCAGLIONE'),
            'studenti' => array(self::BELONGS_TO, 'Studenti', 'COD_FIS'),
        );
    }
}
4

1 回答 1

0

它在 Ssd::model()->find(...) 后失败,并出现“为 foreach() 提供的参数无效”错误。

尤其是:

/var/www/framework/db/schema/CDbCriteria.php(152)
 public function __construct($data=array())
{
foreach($data as $name=>$value)
$this->$name=$value;
}

堆栈跟踪是:

0 /var/www/framework/db/ar/CActiveRecord.php(316): CDbCriteria->__construct(null)

1 /var/www/framework/db/ar/CActiveRecord.php(1338): CActiveRecord->getDbCriteria(false)

2 /var/www/framework/db/ar/CActiveRecord.php(1281): CActiveRecord->applyScopes(CDbCriteria)

3 /var/www/framework/db/ar/CActiveRecord.php(1392): CActiveRecord->查询(CDbCriteria)

4 /var/www/concorsi/protected/controllers/ConfermaController.php(405): CActiveRecord->find(array("condition" => "id_scaglione=:sca AND COD_FIS LIKE :cf", "params" => array( ":sca" => $sca_attivo->attributes['ID_SCAGLIONE'], ":cf" => $codfisc)))

于 2014-07-04T07:43:11.467 回答