예제 #1
0
파일: PredicateTest.php 프로젝트: titon/db
 public function testEither()
 {
     $either = new Predicate(Predicate::EITHER);
     $either->notEq('level', 1)->notEq('level', 2);
     $this->object->either(function (Predicate $predicate) {
         $predicate->notEq('level', 1)->notEq('level', 2);
     });
     $this->assertEquals([$either], $this->object->getParams());
 }
예제 #2
0
파일: Query.php 프로젝트: titon/db
 /**
  * Modify a predicate by adding additional clauses.
  *
  * @param \Titon\Db\Query\Predicate $predicate
  * @param int $type
  * @param string $field
  * @param mixed $op
  * @param mixed $value
  * @return $this
  * @throws \Titon\Db\Exception\ExistingPredicateException
  */
 protected function _modifyPredicate(&$predicate, $type, $field, $op, $value)
 {
     if (!$predicate) {
         $predicate = new Predicate($type);
     } else {
         if ($predicate->getType() !== $type) {
             throw new ExistingPredicateException(sprintf('Predicate clause already created using "%s" conjunction', $predicate->getType()));
         }
     }
     if ($field instanceof Closure) {
         $predicate->bindCallback($field, $this);
     } else {
         if ($value !== null || in_array($op, [Expr::NULL, Expr::NOT_NULL], true)) {
             $predicate->add($field, $op, $value);
         } else {
             if ($op === '!=') {
                 $predicate->notEq($field, $value);
             } else {
                 $predicate->eq($field, $op);
             }
         }
     }
     return $this;
 }