php - 具有复合主键的 Yii 模型

标签 php mysql indexing yii 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 之前会检查这些规则,并且只有在所有规则都正确的情况下才会保存。阅读 Data Validation section of Definitive Guide获取更多信息。

关于php - 具有复合主键的 Yii 模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8985304/

相关文章:

php - PHP 是否具有与这种类型的 Python 字符串替换等效的功能?

php - 使用 SSL 从 PHP 发送电子邮件以及在 outlook 的接收端需要什么配置

php - 需要帮助从 javascript 中的 onclick 函数保存文件

MYSQL - 我应该使用多个子表还是一个子表作为数据描述符?

mysql - 如何在使用 MySQL 别名的查询中使用假名?

mysql - excel vba mysql ado连接

postgresql - 基于地理类型列问题的GIST索引表达式

javascript - XMLHttpRequest/Ajax链接执行位置

Python 3 - 我是否正确使用了索引?

sql-server - : Clustered indexes are stored physically on the table? 这句话是什么意思