我必须验证表中是否存在具有双主键的记录。
$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'),
);
}
}