Zend-framework DB:OR而不是AND运算符

Bou*_*nce 10 zend-framework zend-db

有这样的zend查询:

$select = $this->_table
               ->select()
               ->where('title LIKE  ?', '%'.$searchWord.'%')
               ->where('description LIKE  ?', '%'.$searchWord.'%')
               ->where('verified=1 AND activated=1');
Run Code Online (Sandbox Code Playgroud)

换句话说,它看起来像:

SELECT `some_table`.* FROM `some_table` WHERE (title LIKE '%nice house%') AND (description LIKE '%nice house%') AND (verified=1 AND activated=1)
Run Code Online (Sandbox Code Playgroud)

如果我有几个AND语句,zend通过AND运算符连接它.如何将其与OR运算符连接?因为我需要:

...(title LIKE '%nice house%') OR (description LIKE '%nice house%')...
Run Code Online (Sandbox Code Playgroud)

非常感谢您的帮助.

Yan*_*hon 25

$this->_table->select()->orWhere($condition);
Run Code Online (Sandbox Code Playgroud)

要构建更复杂的查询(ig子条件),您可能必须$this->table->getAdapter()->quoteInto()手动使用和编写SELECT.


And*_*eas 5

这里的其他答案不起作用(不再?),当前的解决方案是在where子句中调用nest()和unnest():

$select->where
    ->nest()
        ->equalTo('column1', 1)
        ->or
        ->equalTo('column2', 2)
    ->unnest()
    ->and
    ->equalTo('column3', 3);
Run Code Online (Sandbox Code Playgroud)