1

CakePHPfindを使用してデータを取得しています。条件間で使用する必要があるORため、CakePHP のドキュメントに記載されているように、次のクエリを使用しました。OR arrayこれは他の場合には完全に機能しますが、この場合、フィールド名が同じである場合に問題が発生しGroup.arrival_dateます。

$this->Group->find('all', 
               array('conditions' => array(
                       'OR' => array( 
                          'Group.arrival_date' => 'DATE_ADD(CURDATE(), INTERVAL 30 DAY)',
                          'Group.arrival_date' => 'DATE_ADD(CURDATE(), INTERVAL 7 DAY)'
                       )
                   )
                ));

それが生成するSQLは

SELECT `Group`.`id`, `Group`.`rr_no`, `Group`.`package_id`, `Group`.`user_id`, 
`Group`.`group_name`, `Group`.`pax`, `Group`.`agent_id`, `Group`.`staff_id`, 
`Group`.`arrival_date`, `Group`.`departure_date`, `Group`.`status`, `Group`.`slug`, 
`Group`.`book_flight`, `Group`.`allocated_tents`, `Group`.`alert`, `Group`.`alert_seen` 
FROM `groups` AS `Group` WHERE `Group`.`arrival_date` = 'DATE_ADD(CURDATE(), INTERVAL 7 DAY)'

2 番目の条件のみが必要です。次のような異なるフィールド名の場合:

$this->Group->find('all', 
                array('conditions' => array(                                                                    
                          'OR' => array( 
                            'Group.slug' => 'slug1',
                            'Group.group_name' => 'group1'
                          )
                      )
              ));

生成されたSQLは

SELECT `Group`.`id`, `Group`.`rr_no`, `Group`.`package_id`, `Group`.`user_id`, 
`Group`.`group_name`, `Group`.`pax`, `Group`.`agent_id`, `Group`.`staff_id`, 
`Group`.`arrival_date`, `Group`.`departure_date`, `Group`.`status`, `Group`.`slug`, 
`Group`.`book_flight`, `Group`.`allocated_tents`, `Group`.`alert`, `Group`.`alert_seen` 
FROM `groups` AS `Group` WHERE ((`Group`.`slug` = 'slug1') OR (`Group`.`group_name` = 'group1'))

これは予想どおりです。私が使用した最初の検索で何が欠けていますか? 上記のクエリを機能させるにはどうすればよいですか? どんな助けでも大歓迎です。CakePHP 2.0 を使用しています。

4

2 に答える 2

1

試す:

$this->Group->find('all', 
               array('conditions' => array(
                       'OR' => array( 
                          array('Group.arrival_date' => 'DATE_ADD(CURDATE(), INTERVAL 30 DAY)'),
                          array('Group.arrival_date' => 'DATE_ADD(CURDATE(), INTERVAL 7 DAY)')
                       )
                   )
                ));

または、次を使用できますIN

$this->Group->find('all', 
                 array('conditions' => array(
                     'Group.arrival_date' => array('DATE_ADD(CURDATE(), INTERVAL 30 DAY)', 'DATE_ADD(CURDATE(), INTERVAL 7 DAY)')
                  )
              );
于 2013-08-12T05:47:57.433 に答える