foo('bar') * but concrete adapters should be able to recognise it * * The call will be iterpreted as clause 'foo' with argument 'bar' * * @param string $name Clause/method name * @param mixed $args * @return Zend_Cloud_DocumentService_Query */ public function __call($name, $args) { $this->_clauses[] = array(strtolower($name), $args); return $this; } /** * SELECT clause (fields to be selected) * * @param null|string|array $select * @return Zend_Cloud_DocumentService_Query */ public function select($select) { if (empty($select)) { return $this; } if (!is_string($select) && !is_array($select)) { throw new Zend_Cloud_DocumentService_Exception("SELECT argument must be a string or an array of strings"); } $this->_clauses[] = array(self::QUERY_SELECT, $select); return $this; } /** * FROM clause * * @param string $name Field names * @return Zend_Cloud_DocumentService_Query */ public function from($name) { if(!is_string($name)) { throw new Zend_Cloud_DocumentService_Exception("FROM argument must be a string"); } $this->_clauses[] = array(self::QUERY_FROM, $name); return $this; } /** * WHERE query * * @param string $cond Condition * @param array $args Arguments to substitute instead of ?'s in condition * @param string $op relation to other clauses - and/or * @return Zend_Cloud_DocumentService_Query */ public function where($cond, $value = null, $op = 'and') { if (!is_string($cond)) { throw new Zend_Cloud_DocumentService_Exception("WHERE argument must be a string"); } $this->_clauses[] = array(self::QUERY_WHERE, array($cond, $value, $op)); return $this; } /** * Select record or fields by ID * * @param string|int $value Identifier to select by * @return Zend_Cloud_DocumentService_Query */ public function whereId($value) { if (!is_scalar($value)) { throw new Zend_Cloud_DocumentService_Exception("WHEREID argument must be a scalar"); } $this->_clauses[] = array(self::QUERY_WHEREID, $value); return $this; } /** * LIMIT clause (how many items to return) * * @param int $limit * @return Zend_Cloud_DocumentService_Query */ public function limit($limit) { if ($limit != (int) $limit) { throw new Zend_Cloud_DocumentService_Exception("LIMIT argument must be an integer"); } $this->_clauses[] = array(self::QUERY_LIMIT, $limit); return $this; } /** * ORDER clause; field or fields to sort by, and direction to sort * * @param string|int|array $sort * @param string $direction * @return Zend_Cloud_DocumentService_Query */ public function order($sort, $direction = 'asc') { $this->_clauses[] = array(self::QUERY_ORDER, array($sort, $direction)); return $this; } /** * "Assemble" the query * * Simply returns the clauses present. * * @return array */ public function assemble() { return $this->getClauses(); } /** * Return query clauses as an array * * @return array Clauses in the query */ public function getClauses() { return $this->_clauses; } }