具有复合主键的Yii模型

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之前检查这些规则,只有在所有规则都正常的情况下才会保存.有关详细信息,请阅读" 权威指南"的" 数据验证"部分.