我的MySQL表的主表是由两列组成的:space_id(INTEGER)和day(DATE)。
CREATE TABLE `ck_space_calendar_cache` (
`space_id` int(11) NOT NULL,
`day` date NOT NULL,
`available` tinyint(1) unsigned NOT NULL DEFAULT '0',
`price` decimal(12,2) DEFAULT NULL,
`offer` varchar(45) DEFAULT NULL,
`presale_date` date DEFAULT NULL,
`presale_price` decimal(12,2) DEFAULT NULL,
`value_x` int(11) DEFAULT NULL,
`value_y` int(11) DEFAULT NULL,
PRIMARY KEY (`space_id`,`day`),
KEY `space` (`space_id`),
CONSTRAINT `space` FOREIGN KEY (`space_id`) REFERENCES `ck_space` (`id`) ON DELETE CASCADE ON UPDATE NO ACTION
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
它在原始SQL中运行良好,如果我试图创建重复项,它会抱怨,但允许我在同一天或同一个space_id创建行。
然而,在Yii中,当使用new Object()和save()时,它会抱怨"space_id"必须是唯一的。
如果重要的话,我使用"Giix"生成模型。
我试图将此代码添加到模型中,但没有帮助:
public function primaryKey(){
return array('space_id', 'day');
}
将此代码添加到ActiveRecord类中是可以的,但应该不是必需的,因为Yii已经从MySQL表声明中获得了这些信息。
public function primaryKey(){
return array('space_id', 'day');
}
当Yii抱怨"space_id"是唯一的时,giix可能已经在ActiveRecord类的rules()中添加了一个验证规则。在保存ActiveRecord之前会检查这些规则,并且只有在所有规则都正常的情况下才会保存。有关详细信息,请阅读《最终指南》的"数据验证"部分。
据我所知,由于Yii 1.1复合主键不再支持Gii,这让许多开发人员感到沮丧。除了返回一个数组作为主键之外,代码中还需要其他文档不完整的更改。
我发现最好的解释是在Yii论坛的这场讨论中。