【发布时间】:2024-01-23 20:26:01
【问题描述】:
我的 MySQL 表的主表是 2 列的组合: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');
}
【问题讨论】:
标签: php mysql indexing yii primary-key