douzhang2092 2013-09-06 17:16
浏览 24
已采纳

在两个过滤器之间推动Symfony2“OR”

I'm trying get from my database some datas which must start or end in an interval :

The basic SQL Query looks like that :

SELECT broadcast.id, broadcast.id_channel, broadcast.start_at, broadcast.real_start_at, broadcast.real_end_at, broadcast.title, broadcast.sended, FROM `broadcast` 
WHERE (
    (broadcast.real_start_at >= :p1 AND broadcast.real_start_at <= :p2) 
    OR 
    (broadcast.real_end_at >= :p3 AND broadcast.real_end_at <= :p4)) 
    AND broadcast.sended=:p5 AND broadcast.id_plurimedia=:p6 
LIMIT 50

The propel query is this one :

$broadcastsQuery = BroadcastQuery::create()
        ->limit(20);
        ->condition('cond1', 'broadcast.real_start_at >= ?', $this->date_start, \Criteria::GREATER_EQUAL)
        ->condition('cond2', 'broadcast.real_start_at <= ?', $this->date_end, \Criteria::LESS_EQUAL)
        ->combine(array('cond1', 'cond2'), \Criteria::LOGICAL_AND, 'cond3')
        ->condition('cond4', 'broadcast.real_end_at >= ?', $this->date_start, \Criteria::GREATER_EQUAL)
        ->condition('cond5', 'broadcast.real_end_at <= ?', $this->date_end, \Criteria::LESS_EQUAL)
        ->combine(array('cond4', 'cond5'), \Criteria::LOGICAL_AND, 'cond6')
        ->where(array('cond3', 'cond6'), null, 'OR');
        ->filterBySended(true)
        ->find();

When I'm executing my script I've this error :

Unable to execute SELECT statement [SELECT broadcast.id, broadcast.id_channel, broadcast.id_plurimedia, broadcast.id_aedra, broadcast.start_at, broadcast.real_start_at, broadcast.real_end_at, broadcast.title, broadcast.sended, broadcast.date_creation, broadcast.date_edition FROM `broadcast` WHERE ((broadcast.real_start_at >= :p1 AND broadcast.real_start_at <= :p2) AND (broadcast.real_end_at >= :p3 AND broadcast.real_end_at <= :p4)) AND broadcast.sended=:p5 LIMIT 50] [wrapped: Warning: PDOStatement::bindValue() expects parameter 3 to be long, string given in /var/www/projectKI/vendor/propel/propel1/runtime/lib/connection/DebugPDOStatement.php line 114] (500 Internal Server Error)

I don't really understand why I'm getting an error and why my query has an "AND" statement instead of an "OR".

  • 写回答

1条回答 默认 最新

  • douzhenyu6533 2013-09-07 23:43
    关注

    I noticed that Propel can't do a simple "OR" (_or()) between 2 filters wich contains date intervals.

    And It also has problem with Criteria so I resolved my problem by replacing criteria with string

    $broadcastQuery->condition('c1', 'broadcast.real_start_at > ?', $this->date_start)
                   ->condition('c2', 'broadcast.real_start_at < ?', $this->date_end)
                   ->combine(array('c1', 'c2'), 'and', 'c3')
                   ->condition('c1', 'broadcast.real_end_at > ?', $this->date_start)
                   ->condition('c2', 'broadcast.real_end_at < ?', $this->date_end)
                   ->combine(array('c1', 'c2'), 'and', 'c4')
                   ->combine(array('c3', 'c4'), 'or');
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置