duandu1966 2013-08-12 05:40
浏览 83
已采纳

使用'OR'的CakePHP SQL操作

I am using CakePHP find to retrieve the data. I need to use OR between conditions so i used following query as stated in CakePHP documentation. This works perfectly other times but the problem arises when the field name is same in OR array, Group.arrival_date in this case.

$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)'
                       )
                   )
                ));

The SQL it generate is

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)'

It takes the second condition only. For different field name like:

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

The generated SQL is

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'))

Which is as expected. What am i missing in the first find i used? How can i get the above query work? Any help would be greatly appreciated. I am using CakePHP 2.0.

  • 写回答

2条回答 默认 最新

  • doupin8555 2013-08-12 05:47
    关注

    Try:

    $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)')
                           )
                       )
                    ));
    

    Or you could use IN:

    $this->Group->find('all', 
                     array('conditions' => array(
                         'Group.arrival_date' => array('DATE_ADD(CURDATE(), INTERVAL 30 DAY)', 'DATE_ADD(CURDATE(), INTERVAL 7 DAY)')
                      )
                  );
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 socket通信实现多人聊天室疑惑
  • ¥15 DEV-C++编译缺失
  • ¥33 找熟练码农写段Pyhthon程序
  • ¥100 怎么让数据库字段自动更新
  • ¥15 antv g6 力导向图布局
  • ¥15 quartz框架,No record found for selection of Trigger with key
  • ¥15 锅炉建模+优化算法,遗传算法优化锅炉燃烧模型,ls-svm会搞,后面的智能算法不会
  • ¥20 MATLAB多目标优化问题求解
  • ¥15 windows2003服务器按你VPN教程设置后,本地win10如何连接?
  • ¥15 求一阶微分方程的幂级数