【问题标题】:Yii Model with composite primary key具有复合主键的 Yii 模型
【发布时间】: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


    【解决方案1】:

    将此代码添加到您的 ActiveRecord 类是可以的,但不是必需的,因为 Yii 已经从您的 MySQL 表声明中获得了该信息。

        public function primaryKey(){
           return array('space_id', 'day');
        }
    

    当 Yii 抱怨 "space_id" 是唯一的时,giix 可能在你的 ActiveRecord 类的 rules() 中添加了一个验证规则。在保存 ActiveRecord 之前检查这些规则,并且只有在所有规则都正常时才会保存。阅读Data Validation section of Definitive Guide了解更多信息。

    【讨论】:

    • giix 正在做一些验证
    【解决方案2】:

    据我了解,由于 Gii 不再支持 Yii 1.1 复合主键,这让许多开发人员感到沮丧。除了将数组作为主键返回之外,您的代码中还需要进行其他记录不充分的更改。

    The best explanation I found was in this discussion in the Yii forum.

    【讨论】: