Модель Yii с составным первичным ключом - PullRequest
6 голосов
/ 24 января 2012

Первичная таблица 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');
        }

Ответы [ 2 ]

11 голосов
/ 12 марта 2012

Добавление этого кода в ваш класс ActiveRecord - это нормально, но в этом нет необходимости, поскольку в Yii уже есть эта информация из объявления таблицы MySQL.

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

Когда Yii жалуется, что «space_id» уникален,giix мог добавить правило проверки к rules () в вашем классе ActiveRecord.Эти правила проверяются перед сохранением ActiveRecord, и он будет сохранен, только если все правила в порядке.Прочитайте раздел Проверка данных в Руководстве по определению для получения дополнительной информации.

0 голосов
/ 27 января 2012

Из того, что я понимаю, поскольку Yii 1.1 составные первичные ключи больше не поддерживаются в Gii, что расстраивает многих разработчиков. Существуют и другие плохо документированные изменения, необходимые в вашем коде, кроме возврата массива в качестве первичного ключа.

Лучшее объяснение, которое я нашел, было в этой дискуссии на форуме Yii.

...