1

したがって、1対多の関係を持つクラスがあります。イベントタイプ:

var $hasMany = array(
    'Event' => array(
        'className' => 'Event',
        'foreignKey' => 'event_type_initials',
        'dependent' => false,
    )
); 

イベント:

var $belongsTo = array(
    'EventType' => array(
        'className' => 'EventType',
        'foreignKey' => 'event_type_initials'
    )
);

以前は、関係はevent_type_idによるものでしたが、現在はinitalsに変更されています。データにアクセスしようとすると、クエリで問題が発生します。次のクエリの最後に、左結合がであることがわかりますEventevent_type_initials= EventTypeid、これは意味がありません。

SELECT `Event`.`id`, `Event`.`event_type_initials`, `Event`.`user_id`, `Event`.`details`, `Event`.`start`, `Event`.`hours`, `Event`.`minutes`, `Event`.`all_day`, `Event`.`active`, `Event`.`created`, `Event`.`modified`, `EventType`.`id`, `EventType`.`initials`, `EventType`.`name`, `EventType`.`address`, `EventType`.`email`, `EventType`.`phone`, `EventType`.`person`, `EventType`.`color` FROM `sunshine3`.`events` AS `Event` LEFT JOIN `sunshine3`.`event_types` AS `EventType` ON (**`Event`.`event_type_initials` = `EventType`.`id`**) WHERE `Event`.`id` = 30

どんな助けでも大歓迎です。

4

1 に答える 1

3

foreignKey を指定すると、関連するテーブルの ID と常に一致します。ただし、ここでは条件を使用する必要があります。

// this is important for the correct left joins
var $belongsTo = array(
    'EventType' => array(
        'className' => 'EventType',
        'foreignKey' => false,
        'conditions' => array('Event.event_type_initials = EventType.initials')
    )
);

// for has many this is usually not necessary/possible (1:n), you can try though
var $hasMany = array(
    'Event' => array(
        'className' => 'Event',
        'foreignKey' => false,
        'conditions' => 'Event.event_type_initials = EventType.initials'
    )
); 
于 2013-02-11T13:29:33.190 に答える