From 5e95d277210520b2b06cb070af09a422d4a78722 Mon Sep 17 00:00:00 2001 From: Nuno Chaves Date: Fri, 11 Jan 2019 11:57:23 +0000 Subject: [PATCH] added whereNotIn() method --- src/QueryBuilder.php | 81 +++++++++++++++++++++++++++++++------------- 1 file changed, 58 insertions(+), 23 deletions(-) diff --git a/src/QueryBuilder.php b/src/QueryBuilder.php index bbf5072..71dbdfb 100644 --- a/src/QueryBuilder.php +++ b/src/QueryBuilder.php @@ -60,21 +60,19 @@ public function setCollection(CosmosDbCollection $collection) /** - * @param $fields + * @param string|array $fields * @return $this */ - public function select($fields) - { - - if (is_array($fields)) - $fields = 'c["' . implode('"], c["', $fields) . '"]'; - - $this->fields = $fields; - return $this; - } + public function select($fields) + { + if (is_array($fields)) + $fields = 'c["' . implode('"], c["', $fields) . '"]'; + $this->fields = $fields; + return $this; + } /** - * @param $from + * @param string $from * @return $this */ public function from($from) @@ -85,7 +83,7 @@ public function from($from) /** - * @param $join + * @param string $join * @return $this */ public function join($join) @@ -96,7 +94,7 @@ public function join($join) /** - * @param $where + * @param string $where * @return $this */ public function where($where) @@ -107,31 +105,65 @@ public function where($where) return $this; } - public function whereStartsWith($field, $value) + /** + * @param string $field + * @param string $value + * @return QueryBuilder + */ + public function whereStartsWith($field, $value) { return $this->where("STARTSWITH($field, '{$value}')"); } - public function whereEndsWith($field, $value) + /** + * @param string $field + * @param string $value + * @return QueryBuilder + */ + public function whereEndsWith($field, $value) { return $this->where("ENDSWITH($field, '{$value}')"); } - public function whereContains($field, $value) + /** + * @param string $field + * @param string $value + * @return QueryBuilder + */ + public function whereContains($field, $value) { return $this->where("CONTAINS($field, '{$value}'"); } - public function whereIn($field, $values) + /** + * @param string $field + * @param array $values + * @return $this|QueryBuilder + */ + public function whereIn($field, $values) { - if (is_array($values)) - $values = implode("', '", $values); + if (!is_array($values) || empty($values)) return $this; + if (is_array($values)) $values = implode("', '", $values); + return $this->where("$field IN('{$values}')"); } + /** + * @param string $field + * @param array $values + * @return $this|QueryBuilder + */ + public function whereNotIn($field, $values) + { + if (!is_array($values) || empty($values)) return $this; + if (is_array($values)) $values = implode("', '", $values); + + return $this->where("$field NOT IN('{$values}')"); + } + /** - * @param $order + * @param string $order * @return $this */ public function order($order) @@ -142,12 +174,12 @@ public function order($order) /** - * @param $limit + * @param int $limit * @return $this */ public function limit($limit) { - $this->limit = $limit; + $this->limit = (int)$limit; return $this; } @@ -232,7 +264,10 @@ public function setPartitionKey($fieldName) return $this; } - public function getPartitionKey() + /** + * @return null + */ + public function getPartitionKey() { return $this->partitionKey; }