具有复合主键的Yii模型


Yii Model with composite primary key

我的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论坛的这场讨论中。