Nat*_*n H 6 php mysql indexing primary-key yii
我的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;
Run Code Online (Sandbox Code Playgroud)
它在原始SQL中运行良好,如果我尝试创建副本,它会抱怨,但让我在同一天或相同的space_id创建行.
但是,在Yii中使用新的Object()和save()时,它会抱怨"space_id"必须是唯一的.
如果重要的话,我使用"Giix"来生成模型.
我试图将此代码添加到模型中,但它没有帮助:
public function primaryKey(){
return array('space_id', 'day');
}
Run Code Online (Sandbox Code Playgroud)
ceb*_*ebe 11
将此代码添加到ActiveRecord类是可以的,但不应该是必需的,因为Yii已经从MySQL表声明中获取了该信息.
public function primaryKey(){
return array('space_id', 'day');
}
Run Code Online (Sandbox Code Playgroud)
当Yii抱怨"space_id"是唯一的时,giix可能会在ActiveRecord类的rules()中添加一个验证规则.在保存ActiveRecord之前检查这些规则,只有在所有规则都正常的情况下才会保存.有关详细信息,请阅读" 权威指南"的" 数据验证"部分.
| 归档时间: |
|
| 查看次数: |
21844 次 |
| 最近记录: |