我的 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 之前会检查这些规则,并且只有在所有规则都正确的情况下才会保存。阅读 Data Validation section of Definitive Guide获取更多信息。
关于php - 具有复合主键的 Yii 模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8985304/